rsj0315 发表于 2020-12-11 21:29:13

pyqt5,如何把一个写好的tableview添加到tab上去

两个py文件,第一个文件是把表格中数据用pandas读成dataframe。
然后model,view形成tabelview
代码如下:
import sys
import pandas as pd
from PyQt5.QtWidgets import QApplication, QTableView
from PyQt5.QtCore import QAbstractTableModel, Qt

def read_df():
    path = r'demo.xlsx'
    df = pd.read_excel(path)
    return df
class pandasModel(QAbstractTableModel):

    def __init__(self, data):
      QAbstractTableModel.__init__(self)
      self._data = data

    def rowCount(self, parent=None):
      return self._data.shape

    def columnCount(self, parnet=None):
      return self._data.shape

    def data(self, index, role=Qt.DisplayRole):
      if index.isValid():
            if role == Qt.DisplayRole:
                return str(self._data.iloc)
      return None

    def headerData(self, col, orientation, role):
      if orientation == Qt.Horizontal and role == Qt.DisplayRole:
            return self._data.columns
      return None

if __name__ == '__main__':
    app = QApplication(sys.argv)
    model = pandasModel(read_df())
    view = QTableView()
    view.setModel(model)
    view.resize(800, 600)
    view.show()
    sys.exit(app.exec_())

然后另外一个py文件建立tab多页的ui,
想把上边的tableview添加到tab上。最好是有一个按钮,点击按钮tableview显示出来。
第二个py文件如下
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *




class Demo(QTabWidget):
    def __init__(self,parent = None):
      super(Demo, self).__init__(parent)
      self.tab1 = QWidget()
      self.tab2 = QWidget()

      self.addTab(self.tab1,'111')
      self.addTab(self.tab2, '222')
      self.tab1UI()

    def tab1UI(self):
      layout = QFormLayout()
      layout.addRow('name',QLineEdit())
      layout.addRow(QPushButton('点击我显示tableview'))
      self.setTabText(0,'改列名试试')
      self.tab1.setLayout(layout)

if __name__ == '__main__':
    app=QApplication(sys.argv)
    form = Demo()
    form.show()
    sys.exit(app.exec_())
想实现的效果如下


hrp 发表于 2020-12-11 22:38:43

本帖最后由 hrp 于 2020-12-11 23:26 编辑

import sys
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *


class Demo(QTabWidget):
    def __init__(self, parent=None):
      super(Demo, self).__init__(parent)
      self.tab1 = QWidget()
      self.tab2 = QWidget()
      # QTableView实例
      self.table_view = QTableView()

      self.addTab(self.tab1, '111')
      self.addTab(self.tab2, '222')
      self.tab1UI()

    def tab1UI(self):
      layout = QFormLayout()
      layout.addRow('name', QLineEdit())
      layout.addRow(QPushButton('点击我显示tableview'))
      # 增加一个QTableView就可以了
      # 至于按钮的点击:
      # 设置点击信号连接到一个新函数,该函数进行self.table_view的各种更新操作
      # 比如对self.table_view设置model啊清空啊啥的
      layout.addWidget(self.table_view)
      self.setTabText(0, '改列名试试')
      self.tab1.setLayout(layout)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    form = Demo()
    form.show()
    sys.exit(app.exec_())

rsj0315 发表于 2020-12-12 00:18:51

hrp 发表于 2020-12-11 22:38


刚才看了下你的那个案例中排序。
没太看懂,只是看到你的展现表格是用的tablewidget

我这个例子里边,tableview要是想实现点解表头,进行排序,有啥思路或者建议吗?

hrp 发表于 2020-12-12 07:35:40

本帖最后由 hrp 于 2020-12-12 11:45 编辑

rsj0315 发表于 2020-12-12 00:18
刚才看了下你的那个案例中排序。
没太看懂,只是看到你的展现表格是用的tablewidget



思路是
1.将点击表头的信号连接到一个自定义的排序槽函数sort_by_column(我的例子是self.tw_installed_info.horizontalHeader().sectionClicked.connect(
            self.sort_by_column
      ),这个int是点击表头时自动传给sort_by_column的列索引)
2.槽函数sort_by_column接收一个列索引参数,然后将源数据source按列索引对应的数据进行排序,事先定义一个实例属性_reversed来记录排序是否反转(我的例子中_reversed是一个列表,分别记录4列的排序是否需要反转),排序时根据是否反转来排序,排序后将_reversed中对应列的True改为False或者相反,方便下次排序时根据这个值进行反向排序或正向排序
3.然后再调用一个自定义函数update,这个函数首先清空原QTableWiew的model或者干脆换个model,根据源数据source重新构建QTableWiew的model(我那个程序因为用的是QTableWidget所以不用model),然后再setModel。
页: [1]
查看完整版本: pyqt5,如何把一个写好的tableview添加到tab上去