这可能是由于PyQt-5.5处理异常的方式发生了变化。引用PyQt5文档:
在PyQt
v5.5中,未处理的Python异常将导致调用Qt的qFatal()函数。默认情况下,它将调用abort(),应用程序将终止。请注意,应用程序安装的异常挂钩仍将优先。
当我在普通控制台中运行您的示例时,这是我看到的:
$ python test.pyTraceback (most recent call last): File "test.py", line 213, in testfunc print(9/0)ZeroDivisionError: division by zeroAborted (core dumped)
因此,主要区别在于,应用程序现在会在遇到未处理的异常时立即终止(即,就像普通的python脚本一样)。当然,您仍然可以通过使用
try/except块或通过覆盖sys.excepthook来全局控制此行为。
如果没有看到任何回溯,则可能是由于您用于运行应用程序的Python IDE出现问题。
PS:
作为最低要求,可以像下面那样恢复仅将跟踪记录打印到stdout / stderr的旧PyQt4行为:
def except_hook(cls, exception, traceback): sys.__excepthook__(cls, exception, traceback)if __name__ == "__main__": import sys sys.excepthook = except_hook
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)