我目前正在使用PyQt5在我的Python程序的用户界面上工作。
在我的程序中,我首先读取一个csv文件,然后使用熊猫创建一个数据框。到目前为止也可以。
现在,我想使用PyQt5创建用户界面。该界面应包含带有两个按钮(“文件”和“运行”)的菜单栏,并应显示我的数据框(参见图片)。
最后看起来应该如何
使用第一个按钮,我想读取我的csv文件,而另一个按钮,我想启动程序。
当前,我只能使用用户界面(参见图片)显示数据框。
现在看起来如何
这是我目前的代码,带有随机数据帧
import sys
import pandas as pd
from PyQt5.QtWidgets import QApplication, QTableView
from PyQt5.QtCore import QAbstractTableModel, Qt
df = pd.DataFrame({'A': ['AAAAAAAA11111111', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz'],
'B': ['BBBBBBBB11111111', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz'],
'C': ['CCCCCCCC11111111', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz'],
'D': ['CCCCCCCC11111111', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz', 'xyz']})
class pandasModel(QAbstractTableModel):
def __init__(self, data):
QAbstractTableModel.__init__(self)
self._data = data
def rowCount(self, parent=None):
return self._data.shape[0]
def columnCount(self, parent=None):
return self._data.shape[1]
def data(self, index, role=Qt.DisplayRole):
if index.isValid():
if role == Qt.DisplayRole:
return str(self._data.iloc[index.row(), index.column()])
return None
def headerData(self, col, orientation, role):
if orientation == Qt.Horizontal and role == Qt.DisplayRole:
return self._data.columns[col]
return None
if __name__ == '__main__':
app = QApplication(sys.argv)
model = pandasModel(df)
view = QTableView()
view.setModel(model)
view.resize(800, 300)
view.horizontalHeader().setSectionResizeMode(1)
view.show()
sys.exit(app.exec_())
为了维护所需的用户界面,我创建了带有菜单栏的PyQt Designer界面(请参见图片)。但是我不知道如何链接这两个接口。
从PyQt_Designer设计
来自PyQt Designer的代码:
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_MainWindow(object):
def setupUi(self, MainWindow):
MainWindow.setObjectName("MainWindow")
MainWindow.resize(600, 300)
icon = QtGui.QIcon()
icon.addPixmap(QtGui.QPixmap("../../Desktop/index.png"), QtGui.QIcon.Normal, QtGui.QIcon.Off)
MainWindow.setWindowIcon(icon)
self.centralwidget = QtWidgets.QWidget(MainWindow)
self.centralwidget.setObjectName("centralwidget")
self.tableWidget = QtWidgets.QTableWidget(self.centralwidget)
self.tableWidget.setGeometry(QtCore.QRect(0, 0, 600, 300))
self.tableWidget.viewport().setProperty("cursor", QtGui.QCursor(QtCore.Qt.CrossCursor))
self.tableWidget.setObjectName("tableWidget")
self.tableWidget.setColumnCount(0)
self.tableWidget.setRowCount(0)
MainWindow.setCentralWidget(self.centralwidget)
self.menubar = QtWidgets.QMenuBar(MainWindow)
self.menubar.setGeometry(QtCore.QRect(0, 0, 600, 21))
self.menubar.setObjectName("menubar")
self.menuSelect = QtWidgets.QMenu(self.menubar)
self.menuSelect.setObjectName("menuSelect")
MainWindow.setMenuBar(self.menubar)
self.statusbar = QtWidgets.QStatusBar(MainWindow)
self.statusbar.setObjectName("statusbar")
MainWindow.setStatusBar(self.statusbar)
self.menubar.addAction(self.menuSelect.menuAction())
self.retranslateUi(MainWindow)
QtCore.QMetaObject.connectSlotsByName(MainWindow)
def retranslateUi(self, MainWindow):
_translate = QtCore.QCoreApplication.translate
MainWindow.setWindowTitle(_translate("MainWindow", "Analyser"))
self.menuSelect.setTitle(_translate("MainWindow", "Select File"))
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_())
如何将菜单栏添加到程序中,或者如何将程序链接到PyQt Designer的代码?
首先,阅读PyQt documentation about using Designer。长话短说,您应该never编辑pyuic生成的python文件,但是创建代码并将生成的文件用作模块。阅读文档,您将了解(您可能希望研究第三个示例)。
删除添加的QTableWidget(因为它是错误的小部件类型),将QTableView拖到主窗口,设置布局(右键单击表外部和窗口中的空白区域,然后选择一个在[布局]子菜单中选择“水平”或“垂直”,保存并重建UI文件。
这时,按照文档中的步骤,您只需从类__init__
中设置模型:
from PyQt5.QtWidgets import QApplication, QMainWindow
from PyQt5.QtCore import QAbstractTableModel, Qt
from ui_mainwindow import Ui_MainWindow
class pandasModel(QAbstractTableModel):
# ...
class MainWindow(QMainWindow, Ui_MainWindow):
def __init__(self):
super().__init__()
self.setupUi(self)
self.model = pandasModel(df)
self.tableView.setModel(self.model)
self.actionOpen.triggered.connect(self.doSomething)