我正在用PyQt 5.10编写一个Python应用程序。
看起来我有一些bug /内存泄漏,因为当我在MainWindow上调用close()时,进程一直在运行。经过一些研究和调试后,我能够限制所谓的错误代码。
这是我的主要内容:
if __name__ == '__main__':
app = QApplication(sys.argv)
matteo = God()
matteo.runApp()
sys.exit(app.exec())
在这里你可以找到God class的runApp函数:
def runApp(self):
self.painter = Painter()
self.dbManager = DBManager()
self.userInput = UserInput()
self.excelFile = ExcelFile()
self.painter.connectToClasses(self, ["god","db","ui"])
self.excelFile.connectToClasses(self, ["god",])
self.painter.drawMainWindow()
self.loadConf()
self.openDB(True)
if self.dbManager.error==None:
self.painter.drawSearchWidget()
else:
print("Closed.")
当应用程序无法找到配置文件时,该进程会继续运行,因此它会从头开始创建一个新进程,并要求用户选择要连接的数据库。这会提示错误消息 - 如果所选文件已损坏或格式不正确 - 我认为可能存在问题。
这就是代码:
def checkError(self, classType):
if classType=="db":
error = self.dbManager.error
elif classType=="excel":
error = self.excelFile.error
if error!=None:
self.painter.drawError(classType)
self.userInput.error = self.painter.error.clickedButton()
self.userInput.error = self.painter.error.buttonRole(self.userInput.error)
if (self.userInput.error==1):
self.painter.mainWindow.close()
return 0
return 1
def drawError(self, classType):
if (classType=="db"):
title = "Database"
error = self.dbManager.error
otherButton = "Browse"
elif (classType=="excel"):
title = "Excel file"
error = self.excelFile.error
try:
self.setErrorText(False, error)
if error[0]:
if self.error.icon()!=3:
self.error.setIcon(3)
buttons = self.error.buttons()
for button in buttons:
if button.text()!="Quit":
button.hide()
button.deleteLater()
except AttributeError:
self.error = QMessageBox()
self.setErrorText(True, error)
if (error[0]):
self.error.setIcon(3)
else:
self.error.setIcon(2)
self.error.addButton(otherButton, self.error.AcceptRole)
self.error.addButton("Quit", self.error.RejectRole)
self.error.setWindowTitle(title)
self.error.exec()
如果用户单击错误窗口上的退出按钮,该功能将关闭主窗口并返回0.其他功能返回,应用程序在控制台上打印关闭。但是这个过程一直在继续。
答案 0 :(得分:0)
我解决了这个问题,调用sys.exit()而不是打印关闭。
这至少可以说是一个强力解决方案,但我需要快速交付应用程序,我没有时间调试它。
我想这个悲伤的故事将在这里结束