我正在用Python编写一个命令行实用程序,由于它是生产代码,因此应该能够干净关闭,而不会在屏幕上倾倒一堆东西(错误代码,堆栈跟踪等)。这意味着我需要捕获键盘中断。
我试过使用try catch块,如:
if __name__ == '__main__':
try:
main()
except KeyboardInterrupt:
print 'Interrupted'
sys.exit(0)
并捕获信号本身(如本文中所示):
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
这些错误不仅丑陋,而且不是很有用(特别是对于没有源代码的最终用户)!
此应用程序的清理代码相当大,因此实际用户很有可能会遇到此问题。有什么方法可以捕获或阻止此输出,还是我必须处理的事情?
sys.stdout
/sys.stderr
?像sys.stderr = open(os.devnull, 'w')
?。如果您真的不在乎最终输出,那么这似乎是显而易见的解决方案。