在程序关闭期间捕获Python中的键盘中断

2024-04-19 12:23:22 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在用Python编写一个命令行实用程序,因为它是生产代码,应该能够干净地关闭,而不会将一堆东西(错误代码、堆栈跟踪等)转储到屏幕上。这意味着我需要捕捉键盘中断。

我试过使用两个try-catch块,比如:

if __name__ == '__main__':
    try:
        main()
    except keyboardInterrupt:
        print 'Interrupted'
        sys.exit(0)

捕捉信号本身(如this post):

import signal
import sys

def sigint_handler(signal, frame):
    print 'Interrupted'
    sys.exit(0)
signal.signal(signal.SIGINT, sigint_handler)

这两种方法在正常操作期间似乎都很有效。但是,如果中断发生在应用程序末尾的清理代码期间,Python似乎总是会在屏幕上打印一些内容。抓住中断

^CInterrupted
Exception KeyboardInterrupt in <bound method MyClass.__del__ of <path.to.MyClass object at 0x802852b90>> ignored

而处理信号

^CInterrupted
Exception SystemExit: 0 in <Finalize object, dead> ignored

或者

^CInterrupted
Exception SystemExit: 0 in <bound method MyClass.__del__ of <path.to.MyClass object at 0x802854a90>> ignored

这些错误不仅难看,而且也不是很有帮助(特别是对于没有源代码的最终用户)!

此应用程序的清理代码相当大,因此实际用户很可能会遇到此问题。有什么方法可以捕获或阻止此输出,还是我必须处理它?


Tags: 代码insignalobject屏幕mainsysexit
2条回答

签出this thread,它有一些关于退出和回溯的有用信息。

如果您对终止程序更感兴趣,请尝试类似的操作(这也会从清理代码中去掉腿):

if __name__ == '__main__':
    try:
        main()
    except KeyboardInterrupt:
        print('Interrupted')
        try:
            sys.exit(0)
        except SystemExit:
            os._exit(0)

在启动清理代码之前,可以通过调用signal.signal(signal.SIGINT, signal.SIG_IGN)来忽略关机后的sigint。

相关问题 更多 >