我想在 PyQt5 的 QtableView 中显示一个 csv 文件
Posted
技术标签:
【中文标题】我想在 PyQt5 的 QtableView 中显示一个 csv 文件【英文标题】:I would like to display a csv file in QtableView of PyQt5 【发布时间】:2021-09-14 09:03:24 【问题描述】:我在 QtDesigner 上设计了 GUI 的布局并将其转换为 python 文件。我已经搜索了已经存在的问题以寻找解决方案,但要么我错过了它,要么没有。我想在 GUI 的表格视图中显示我的 csv 文件。
从 PyQt5 导入 QtCore、QtGui、QtWidgets 导入csv
class Ui_MainWindow(object):
#def __init__(self, parent=None):
#self.model = QtGui.QStandardItemModel(self)
def setupUi(self, MainWindow):
MainWindow.setObjectName("MainWindow")
MainWindow.resize(800, 600)
self.centralwidget = QtWidgets.QWidget(MainWindow)
self.centralwidget.setObjectName("centralwidget")
self.tableView = QtWidgets.QTableView(self.centralwidget)
self.tableView.setGeometry(QtCore.QRect(15, 21, 761, 361))
self.tableView.setObjectName("tableView")
#self.tableView.setModel(self.model)
self.tableView.horizontalHeader().setStretchLastSection(True)
self.pushButton = QtWidgets.QPushButton(self.centralwidget)
self.pushButton.setGeometry(QtCore.QRect(80, 430, 161, 61))
self.pushButton.setObjectName("pushButton")
self.pushButton_2 = QtWidgets.QPushButton(self.centralwidget)
self.pushButton_2.setGeometry(QtCore.QRect(550, 420, 141, 81))
self.pushButton_2.setObjectName("pushButton_2")
MainWindow.setCentralWidget(self.centralwidget)
self.menubar = QtWidgets.QMenuBar(MainWindow)
self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 21))
self.menubar.setObjectName("menubar")
MainWindow.setMenuBar(self.menubar)
self.statusbar = QtWidgets.QStatusBar(MainWindow)
self.statusbar.setObjectName("statusbar")
MainWindow.setStatusBar(self.statusbar)
self.pushButton.clicked.connect(self.loadCsv)
self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)
def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
self.pushButton.setText(_translate("MainWindow", "PushButton"))
self.pushButton_2.setText(_translate("MainWindow", "PushButton"))
def loadCsv(self):
fileName = 'C:/Users/Rada1/Desktop/data.csv'
with open(fileName, "r") as fileInput:
for row in csv.reader(fileInput):
items = [
QtGui.QStandardItem(field)
for field in row
]
self.model.appendRow(items)
if __name__ == "__main__":
import sys
app = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = Ui_MainWindow()
ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())
当我运行这段代码时,我得到了错误
AttributeError: 'Ui_MainWindow' object has no attribute 'model'
然后我尝试将 self.model = QtGui.QStandardItemModel(self)
初始化为 Ui_MainWindow 类,但得到了错误
TypeError: arguments did not match any overloaded call:
QStandardItemModel(parent: QObject = None): argument 1 has unexpected type 'Ui_MainWindow'
QStandardItemModel(int, int, parent: QObject = None): argument 1 has unexpected type 'Ui_MainWindow'
如何让它工作?
【问题讨论】:
【参考方案1】:错误是明确的:QtGui.QStandardItemModel(parent)
期望 QObject
为 parent
;你给它一个object
。
所以你可以例如在 setupUi 中添加这两行:
self.model = QtGui.QStandardItemModel(MainWindow)
self.tableView.setModel(self.model)
【讨论】:
这行得通,谢谢。但由于某种原因,tableview 显示在 csv 文件的每一行之后都会留下一个空白区域。以上是关于我想在 PyQt5 的 QtableView 中显示一个 csv 文件的主要内容,如果未能解决你的问题,请参考以下文章
如何通过在 PyQt5 中按 Enter 键从 QTableView 获取数据
QTableView 和 QStyledItemDelegate 类的使用 (PyQt5)