Python-PyQt5-图形可视化界面(6)-QTableWidget

Ps:水平有限,欢迎建议和挑错
因为一个读者毕业设计需要,写的仓促,见谅

这里省略打开文件按钮,详情见:

https://www.jianshu.com/p/98e8218b2309

QTableWidget是pyqt的一个表格类,每个一个格子是一个Item值。
我们可以用循环将读取的表格写入QTableWidget中。

1、创建表格

class myDialog(QDialog):
    """docstring for myDialog"""
    def __init__(self, arg=None):
        super(myDialog, self).__init__(arg)
        self.setWindowTitle("first window")
        self.resize(841,556);
        self.tableWidget.setGeometry(QtCore.QRect(0, 60, 813, 371))
        self.tableWidget.setObjectName("tableWidget")
        self.tableWidget.setColumnCount(0)
        self.tableWidget.setRowCount(0)
        self.tableWidget.setStyleSheet("selection-background-color:pink")
        self.tableWidget.setEditTriggers(QAbstractItemView.NoEditTriggers)
        self.tableWidget.raise_()

2、读取数据填入表格

来一个简单的例子:

from PyQt5 import QtCore, QtGui, QtWidgets
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
import pandas as pd
import numpy as np

。。。这里省略打开文件按钮,详情见:
https://www.jianshu.com/p/98e8218b2309
。。。

input_table = pd.read_excel(path_openfile_name)
#打开读取excel表格
input_table_rows = input_table.shape[0]
#获取表格行数
input_table_colunms = input_table.shape[1]
#获取表格列数
#print(input_table_rows)
#print(input_table_colunms)
input_table_header = input_table.columns.values.tolist()
#获取表头
#print(input_table_header)
###===========读取表格,转换表格,==============================
###===========给tablewidget设置行列表头========================
self.tableWidget.setColumnCount(input_table_colunms)
#设置表格列数
self.tableWidget.setRowCount(input_table_rows)
#设置表格行数
self.tableWidget.setHorizontalHeaderLabels(input_table_header) 
#给tablewidget设置行列表头
###===========遍历表格每个元素,同时添加到tablewidget中===========
            for i in range(input_table_rows):
                input_table_rows_values = input_table.iloc[[i]]
                #print(input_table_rows_values)
                input_table_rows_values_array = np.array(input_table_rows_values)
                input_table_rows_values_list = input_table_rows_values_array.tolist()[0]
            #print(input_table_rows_values_list)
                for j in range(input_table_colunms):
                    input_table_items_list = input_table_rows_values_list[j]
                #print(input_table_items_list)
                # print(type(input_table_items_list))

        ###==============将遍历的元素添加到tablewidget中并显示=======================

                    input_table_items = str(input_table_items_list)
                    newItem = QTableWidgetItem(input_table_items) 
                    newItem.setTextAlignment(Qt.AlignHCenter|Qt.AlignVCenter)
                    self.tableWidget.setItem(i, j, newItem)  

你可能感兴趣的:(Python-PyQt5-图形可视化界面(6)-QTableWidget)