我想在 PyQt5 的 QtableView 中显示一个 csv 文件
I would like to display a csv file in QtableView of PyQt5
我在 QtDesigner 上设计了 GUI 的布局,并将其转换为 python 文件。我已经在现有问题中搜索了解决方案,但要么我错过了,要么没有。我想在 GUI 的 table 视图上显示我的 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 Class 但得到了错误
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'
如何让它工作?
错误很明显:QtGui.QStandardItemModel(parent)
期望 QObject
为 parent
;你给它一个 object
.
因此您可以在 setupUi 中添加这两行:
self.model = QtGui.QStandardItemModel(MainWindow)
self.tableView.setModel(self.model)
我在 QtDesigner 上设计了 GUI 的布局,并将其转换为 python 文件。我已经在现有问题中搜索了解决方案,但要么我错过了,要么没有。我想在 GUI 的 table 视图上显示我的 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 Class 但得到了错误
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'
如何让它工作?
错误很明显:QtGui.QStandardItemModel(parent)
期望 QObject
为 parent
;你给它一个 object
.
因此您可以在 setupUi 中添加这两行:
self.model = QtGui.QStandardItemModel(MainWindow)
self.tableView.setModel(self.model)