鱼C论坛

 找回密码
 立即注册
查看: 3246|回复: 3

[已解决]pyqt5,如何把一个写好的tableview添加到tab上去

[复制链接]
发表于 2020-12-11 21:29:13 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

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

  5. def read_df():
  6.     path = r'demo.xlsx'
  7.     df = pd.read_excel(path)
  8.     return df
  9. class pandasModel(QAbstractTableModel):

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

  13.     def rowCount(self, parent=None):
  14.         return self._data.shape[0]

  15.     def columnCount(self, parnet=None):
  16.         return self._data.shape[1]

  17.     def data(self, index, role=Qt.DisplayRole):
  18.         if index.isValid():
  19.             if role == Qt.DisplayRole:
  20.                 return str(self._data.iloc[index.row(), index.column()])
  21.         return None

  22.     def headerData(self, col, orientation, role):
  23.         if orientation == Qt.Horizontal and role == Qt.DisplayRole:
  24.             return self._data.columns[col]
  25.         return None

  26. if __name__ == '__main__':
  27.     app = QApplication(sys.argv)
  28.     model = pandasModel(read_df())
  29.     view = QTableView()
  30.     view.setModel(model)
  31.     view.resize(800, 600)
  32.     view.show()
  33.     sys.exit(app.exec_())
复制代码


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




  5. class Demo(QTabWidget):
  6.     def __init__(self,parent = None):
  7.         super(Demo, self).__init__(parent)
  8.         self.tab1 = QWidget()
  9.         self.tab2 = QWidget()

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

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

  19. if __name__ == '__main__':
  20.     app=QApplication(sys.argv)
  21.     form = Demo()
  22.     form.show()
  23.     sys.exit(app.exec_())
复制代码

想实现的效果如下


最佳答案
2020-12-11 22:38:43
本帖最后由 hrp 于 2020-12-11 23:26 编辑
  1. import sys
  2. from PyQt5.QtWidgets import *
  3. from PyQt5.QtGui import *
  4. from PyQt5.QtCore import *


  5. class Demo(QTabWidget):
  6.     def __init__(self, parent=None):
  7.         super(Demo, self).__init__(parent)
  8.         self.tab1 = QWidget()
  9.         self.tab2 = QWidget()
  10.         # QTableView实例
  11.         self.table_view = QTableView()

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

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


  26. if __name__ == '__main__':
  27.     app = QApplication(sys.argv)
  28.     form = Demo()
  29.     form.show()
  30.     sys.exit(app.exec_())
复制代码
搜狗截图20201211212830.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-12-11 22:38:43 | 显示全部楼层    本楼为最佳答案   
本帖最后由 hrp 于 2020-12-11 23:26 编辑
  1. import sys
  2. from PyQt5.QtWidgets import *
  3. from PyQt5.QtGui import *
  4. from PyQt5.QtCore import *


  5. class Demo(QTabWidget):
  6.     def __init__(self, parent=None):
  7.         super(Demo, self).__init__(parent)
  8.         self.tab1 = QWidget()
  9.         self.tab2 = QWidget()
  10.         # QTableView实例
  11.         self.table_view = QTableView()

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

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


  26. if __name__ == '__main__':
  27.     app = QApplication(sys.argv)
  28.     form = Demo()
  29.     form.show()
  30.     sys.exit(app.exec_())
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-12-12 00:18:51 | 显示全部楼层

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

我这个例子里边,tableview要是想实现点解表头,进行排序,有啥思路或者建议吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-12-12 07:35:40 From FishC Mobile | 显示全部楼层
本帖最后由 hrp 于 2020-12-12 11:45 编辑
rsj0315 发表于 2020-12-12 00:18
刚才看了下你的那个案例中排序。
没太看懂,只是看到你的展现表格是用的tablewidget



思路是
1.将点击表头的信号连接到一个自定义的排序槽函数sort_by_column(我的例子是self.tw_installed_info.horizontalHeader().sectionClicked[int].connect(
            self.sort_by_column
        ),这个int是点击表头时自动传给sort_by_column的列索引)
2.槽函数sort_by_column接收一个列索引参数,然后将源数据source按列索引对应的数据进行排序,事先定义一个实例属性_reversed来记录排序是否反转(我的例子中_reversed是一个列表[True, True, True, True],分别记录4列的排序是否需要反转),排序时根据是否反转来排序,排序后将_reversed中对应列的True改为False或者相反,方便下次排序时根据这个值进行反向排序或正向排序
3.然后再调用一个自定义函数update,这个函数首先清空原QTableWiew的model或者干脆换个model,根据源数据source重新构建QTableWiew的model(我那个程序因为用的是QTableWidget所以不用model),然后再setModel。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-30 15:52

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表