我正在用PyQt 5.10编写一个Python应用程序。
似乎有某种bug/内存泄漏,因为当我在主窗口上调用close()时,进程一直在运行。经过一段时间的研究和调试,我能够限定出所谓的错误代码。
这是我的主要观点:
if __name__ == '__main__':
app = QApplication(sys.argv)
matteo = God()
matteo.runApp()
sys.exit(app.exec())
在这里,您可以找到God类中的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()
如果用户单击错误窗口上的quit按钮,函数将关闭主窗口并返回0。其他函数返回,应用程序在控制台上打印关闭。但这个过程还在继续。你知道吗
我打电话解决了这个问题系统出口()而不是打印关闭。
至少可以说,这是一个暴力解决方案,但我需要快速交付应用程序,我没有时间调试它。
我想这个悲惨的故事将在这里结束。你知道吗
相关问题 更多 >
编程相关推荐