'QMainWindow' 对象没有属性 'addWidget'
'QMainWindow' object has no attribute 'addWidget'
我正在尝试制作具有多个屏幕的 Window 因此我尝试使用 PyQT5 的 Stacked Widget
容器。
为了尝试一下,我在设计器中做了一个简单的 window,然后提取了它的代码。
但是,当我 运行 该代码时,出现错误 'QMainWindow' object has no attribute 'addWidget'
代码如下所示:
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'stack.ui'
#
# Created by: PyQt5 UI code generator 5.15.2
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again. Do not edit this file unless you know what you are doing.
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_StackedWidget(object):
def setupUi(self, StackedWidget):
StackedWidget.setObjectName("StackedWidget")
StackedWidget.resize(400, 300)
self.page = QtWidgets.QWidget()
self.page.setObjectName("page")
self.label = QtWidgets.QLabel(self.page)
self.label.setGeometry(QtCore.QRect(130, 80, 111, 51))
self.label.setObjectName("label")
StackedWidget.addDockWidget(self.page)
self.page_2 = QtWidgets.QWidget()
self.page_2.setObjectName("page_2")
self.label_2 = QtWidgets.QLabel(self.page_2)
self.label_2.setGeometry(QtCore.QRect(90, 160, 161, 91))
self.label_2.setObjectName("label_2")
StackedWidget.addDockWidget(self.page_2)
StackedWidget.
self.retranslateUi(StackedWidget)
StackedWidget.setCurrentIndex(0)
QtCore.QMetaObject.connectSlotsByName(StackedWidget)
def retranslateUi(self, StackedWidget):
_translate = QtCore.QCoreApplication.translate
StackedWidget.setWindowTitle(_translate("StackedWidget", "StackedWidget"))
self.label.setText(_translate("StackedWidget", "first page"))
self.label_2.setText(_translate("StackedWidget", "2nd page"))
if __name__ == "__main__":
import sys
app = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = Ui_StackedWidget()
ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())
正如所有 pyuic 生成文件的 header 中的警告所说,除非您真的知道自己在做什么,否则不应编辑它们。如果您知道自己在做什么,就不会编辑它们。
这是一种礼貌的说法:你必须永远不要编辑这些文件。
您不能尝试将 QMainWindow 与为 QStackedWidget 生成的文件一起使用,因为它们是完全不同的小部件,具有完全不同的用途和功能。
由于无论如何您都可能要使用 QMainWindow,因此最好的解决方案是在 Designer 中创建一个 QMainWindow,然后向其中添加一个 QStackedWidget。只需确保正确设置布局:如果堆叠小部件将成为“主小部件”,则将简单的 vertical/horizontal 盒装布局设置为主布局就足够了:右键单击堆叠小部件外的任意位置,然后 select 从“布局”子菜单中选择合适的布局。
作为替代方案,如果您 selected Designer 的新表单对话框中的那个小部件,如果您也正确遵循有关 using Designer 的指南,例如:
from PyQt5 import QtWidgets
from ui_stackedWidget import Ui_StackedWidget
class MainWindow(QtWidgets.QMainWindow):
def __init__(self):
super().__init__()
self.stackedWidget = QtWidgets.QStackedWidget()
self.ui = Ui_StackedWidget()
self.ui.setupUi(self.stackedWidget)
self.setCentralWidget(self.stackedWidget)
if __name__ == '__main__':
import sys
app = QtWidgets.QApplication(sys.argv)
mainWindow = MainWindow()
mainWindow.show()
sys.exit(app.exec_())
我正在尝试制作具有多个屏幕的 Window 因此我尝试使用 PyQT5 的 Stacked Widget
容器。
为了尝试一下,我在设计器中做了一个简单的 window,然后提取了它的代码。
但是,当我 运行 该代码时,出现错误 'QMainWindow' object has no attribute 'addWidget'
代码如下所示:
# -*- coding: utf-8 -*-
# Form implementation generated from reading ui file 'stack.ui'
#
# Created by: PyQt5 UI code generator 5.15.2
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again. Do not edit this file unless you know what you are doing.
from PyQt5 import QtCore, QtGui, QtWidgets
class Ui_StackedWidget(object):
def setupUi(self, StackedWidget):
StackedWidget.setObjectName("StackedWidget")
StackedWidget.resize(400, 300)
self.page = QtWidgets.QWidget()
self.page.setObjectName("page")
self.label = QtWidgets.QLabel(self.page)
self.label.setGeometry(QtCore.QRect(130, 80, 111, 51))
self.label.setObjectName("label")
StackedWidget.addDockWidget(self.page)
self.page_2 = QtWidgets.QWidget()
self.page_2.setObjectName("page_2")
self.label_2 = QtWidgets.QLabel(self.page_2)
self.label_2.setGeometry(QtCore.QRect(90, 160, 161, 91))
self.label_2.setObjectName("label_2")
StackedWidget.addDockWidget(self.page_2)
StackedWidget.
self.retranslateUi(StackedWidget)
StackedWidget.setCurrentIndex(0)
QtCore.QMetaObject.connectSlotsByName(StackedWidget)
def retranslateUi(self, StackedWidget):
_translate = QtCore.QCoreApplication.translate
StackedWidget.setWindowTitle(_translate("StackedWidget", "StackedWidget"))
self.label.setText(_translate("StackedWidget", "first page"))
self.label_2.setText(_translate("StackedWidget", "2nd page"))
if __name__ == "__main__":
import sys
app = QtWidgets.QApplication(sys.argv)
MainWindow = QtWidgets.QMainWindow()
ui = Ui_StackedWidget()
ui.setupUi(MainWindow)
MainWindow.show()
sys.exit(app.exec_())
正如所有 pyuic 生成文件的 header 中的警告所说,除非您真的知道自己在做什么,否则不应编辑它们。如果您知道自己在做什么,就不会编辑它们。
这是一种礼貌的说法:你必须永远不要编辑这些文件。
您不能尝试将 QMainWindow 与为 QStackedWidget 生成的文件一起使用,因为它们是完全不同的小部件,具有完全不同的用途和功能。
由于无论如何您都可能要使用 QMainWindow,因此最好的解决方案是在 Designer 中创建一个 QMainWindow,然后向其中添加一个 QStackedWidget。只需确保正确设置布局:如果堆叠小部件将成为“主小部件”,则将简单的 vertical/horizontal 盒装布局设置为主布局就足够了:右键单击堆叠小部件外的任意位置,然后 select 从“布局”子菜单中选择合适的布局。
作为替代方案,如果您 selected Designer 的新表单对话框中的那个小部件,如果您也正确遵循有关 using Designer 的指南,例如:
from PyQt5 import QtWidgets
from ui_stackedWidget import Ui_StackedWidget
class MainWindow(QtWidgets.QMainWindow):
def __init__(self):
super().__init__()
self.stackedWidget = QtWidgets.QStackedWidget()
self.ui = Ui_StackedWidget()
self.ui.setupUi(self.stackedWidget)
self.setCentralWidget(self.stackedWidget)
if __name__ == '__main__':
import sys
app = QtWidgets.QApplication(sys.argv)
mainWindow = MainWindow()
mainWindow.show()
sys.exit(app.exec_())