-1

我的代码用一个按钮调用一个窗口。单击按钮时,调用另一个窗口。但是第二个窗口立即关闭

“basic”和“windows_two”是pyuic5从.ui文件生成的.py库

import basic, windows_two
from PyQt5 import QtCore, QtGui, QtWidgets

if __name__ == "__main__":
    
    #Declarations
    import sys
    app = QtWidgets.QApplication(sys.argv)
    
    def Call_Second_Window():
        #Second Screen
        Form = QtWidgets.QWidget()
        ui = windows_two.Ui_Form()
        ui.setupUi(Form)
        Form.show()
        
    def Call_Main_Window():
        #MainWindow
        MainWindow = QtWidgets.QMainWindow()
        ui = basic.Ui_MainWindow()
        ui.setupUi(MainWindow)      
        ui.printButton.clicked.connect(Call_Second_Window) #click event to second window
        MainWindow.show()
        sys.exit(app.exec_())
        
    
    Call_Main_Window()
    

怎么了?

谢谢

4

1 回答 1

1

每当一个变量是本地的,只要函数返回,它就会被“垃圾收集”;这意味着变量可能引用的所有内容也将(可能)被删除。

在您的情况下发生的情况是,虽然正确创建了窗口,但在Call_Second_Window返回时(就在 之后)将立即删除(由于垃圾收集Form.show())。

为了避免这种情况,只有一种解决方案:使对对象的引用持久化。有多种方法可以实现这一点,具体取决于具体情况。

不幸的是,您的代码有点不正统(尤其是从 PyQt 的角度来看),所以我正在“重构”它,以使其更标准化、更好地面向对象,而且更重要的是,更易于阅读。

import basic, windows_two
from PyQt5 import QtWidgets

class MainWindow(QtWidgets.QMainWindow):
    def __init__(self):
        super().__init__()
        self.ui = basic.Ui_MainWindow()
        self.ui.setupUi(self)
        self.ui.printButton.clicked.connect(self.call_Second_Window) 

        self.secondWindow = None

    def call_Second_Window(self):
        if not self.secondWindow:
            self.secondWindow = SecondWindow()
        self.secondWindow.show()


class SecondWindow(QtWidgets.QWidget):
    def __init__(self):
        super().__init__()
        self.ui = windows_two.Ui_Form()
        self.ui.setupUi(self)


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    
    mainWindow = MainWindow()
    mainWindow.show()

    sys.exit(app.exec_())

注意:如您所见,我将名称更改为call_Second_Window小写的“c”,这是因为大写名称只能用于类和常量,而函数名称应始终以小写字母开头。这又是为了可读性,这在编程中非常重要,也是 python 的核心原则之一。在Python 代码的官方样式指南中阅读有关此主题和其他重要主题的更多信息。

于 2020-11-12T14:44:04.243 回答