写一个pyqt5程序的步骤(类,继承,init,类做参数等)
kimi生成的,两种区别和相似在哪。类没有init函数会怎样?
kimi生成
import sys from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QLineEdit class Example(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): # 创建垂直布局 layout = QVBoxLayout(self) # 创建第一个 QLineEdit 控件 self.lineEdit1 = QLineEdit(self) self.lineEdit1.setPlaceholderText("请输入第一个值") layout.addWidget(self.lineEdit1) # 创建第二个 QLineEdit 控件 self.lineEdit2 = QLineEdit(self) self.lineEdit2.setPlaceholderText("请输入第二个值") layout.addWidget(self.lineEdit2) # 设置窗口标题和大小 self.setWindowTitle('两个 QLineEdit 控件示例') self.setGeometry(100, 100, 300, 150) if __name__ == '__main__': app = QApplication(sys.argv) ex = Example() ex.show() sys.exit(app.exec_())
qtdesigner自动生成的
from PyQt5 import QtCore, QtGui, QtWidgets class Ui_MainWindow(object):
# MainWindow是一个QMainWindow类的实例,代表应用程序的主窗口。
# 对象做函数参数
def setupUi(self, MainWindow): MainWindow.setObjectName("MainWindow")
MainWindow.resize(800, 1256) self.centralwidget = QtWidgets.QWidget(MainWindow) self.centralwidget.setObjectName("centralwidget") self.pushButton = QtWidgets.QPushButton(self.centralwidget) self.pushButton.setGeometry(QtCore.QRect(310, 140, 75, 23)) self.pushButton.setObjectName("pushButton") MainWindow.setCentralWidget(self.centralwidget) self.menubar = QtWidgets.QMenuBar(MainWindow) self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 23)) self.menubar.setObjectName("menubar") MainWindow.setMenuBar(self.menubar) self.statusbar = QtWidgets.QStatusBar(MainWindow) self.statusbar.setObjectName("statusbar") MainWindow.setStatusBar(self.statusbar) self.retranslateUi(MainWindow) self.pushButton.clicked.connect(MainWindow.close) # type: ignore QtCore.QMetaObject.connectSlotsByName(MainWindow) def retranslateUi(self, MainWindow): _translate = QtCore.QCoreApplication.translate MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow")) self.pushButton.setText(_translate("MainWindow", "关闭")) import sys # 主方法,程序从此处启动PyQt设计的窗体 if __name__ == '__main__': app = QtWidgets.QApplication(sys.argv) MainWindow = QtWidgets.QMainWindow() # 创建窗体对象 ui = Ui_MainWindow() # 创建PyQt设计的窗体对象 ui.setupUi(MainWindow) # 调用PyQt窗体的方法对窗体对象进行初始化设置
# 用于设置窗口的窗口标志(window flags)。窗口标志定义了窗口的外观和行为,例如是否显示标题栏、是否可以最大化或最小化等。
MainWindow.setWindowFlags(QtCore.Qt.Window) MainWindow.show() # 显示窗体 sys.exit(app.exec_()) # 程序关闭时退出进程
qtdesigner逻辑代码和ui分离的例子
# label.py
from PyQt5 import QtCore, QtGui, QtWidgets class Ui_MainWindow(object):
# 这个setupui为什么要带参数MainWindow def setupUi(self, MainWindow): MainWindow.setObjectName("MainWindow") MainWindow.resize(800, 600) self.centralwidget = QtWidgets.QWidget(MainWindow) self.centralwidget.setObjectName("centralwidget") self.lcdNumber = QtWidgets.QLCDNumber(self.centralwidget) self.lcdNumber.setGeometry(QtCore.QRect(210, 240, 191, 71)) def retranslateUi(self, MainWindow): _translate = QtCore.QCoreApplication.translate MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow")) self.label.setText(_translate("MainWindow", "请输入数字:")) ######################################################################
# label_code.py from PyQt5 import QtWidgets,QtGui,QtCore from label import Ui_MainWindow class MainWindow(QtWidgets.QMainWindow,Ui_MainWindow): def __init__(self,parent = None):
# super不写参数也可以 super(MainWindow,self).__init__(parent) self.setupUi(self) if __name__ == '__main__': import sys app = QtWidgets.QApplication(sys.argv) MainWindow = MainWindow() MainWindow.show() sys.exit(app.exec_())
super不写参数会怎么样?
在 Python 3 中,super() 函数可以不带任何参数使用。当你省略参数时,Python 会自动推断出正确的类和实例。这使得代码更加简洁和易于阅读。
Python 3 中,当你调用 super() 而不提供任何参数时,Python 会自动推断出正确的类和实例。它会查找当前类的父类,并调用该父类的相应方法。
在 Python 2 中,super() 必须提供参数。如果你需要编写兼容 Python 2 的代码,必须使用带参数的 super()。
浙公网安备 33010602011771号