【发布时间】:2011-09-29 16:41:18
【问题描述】:
我想在全球范围内捕获KeyboardInterrupt,并妥善处理它。我不想将我的整个脚本包含在一个巨大的 try/except 语句中。有没有办法做到这一点?
【问题讨论】:
我想在全球范围内捕获KeyboardInterrupt,并妥善处理它。我不想将我的整个脚本包含在一个巨大的 try/except 语句中。有没有办法做到这一点?
【问题讨论】:
您的脚本是否有您调用的函数来启动它?
main()
那就做吧:
try:
main()
except:
...
如果您没有main,而只是一个逐行运行的巨大脚本,那么您应该将它放在main 中。
【讨论】:
没有其他方法可以做到这一点,除了将整个脚本封装在 main() 函数中并用 try..except 块包围它 - 这几乎相同:
def main():
# Your script goes here
pass
if __name__ == "__main__":
try:
main()
except KeyboardInterrupt:
# cleanup code here
pass
【讨论】:
如果这是在命令行上执行的脚本,您可以将运行时逻辑封装在 main() 中,在 if __name__ == '__main__' 中调用它并包装它。
if __name__ == '__main__':
try:
main()
except KeyboardInterrupt:
print 'Killed by user'
sys.exit(0)
【讨论】:
你也可以像这样使用signal:
import signal, time
def handler(signum, frame):
print 'I just clicked on CTRL-C '
signal.signal(signal.SIGINT, handler)
print "waiting for 10 s"
time.sleep(10)
输出:
waiting for 10 s
^CI just clicked on CTRL-C
注意:不要将信号与线程混合使用。
【讨论】:
KeyboardInterrupt 异常也是从信号处理程序引发的。
如果您真的不想使用try/except,可以更改sys.excepthook。
import sys
def my_except_hook(exctype, value, traceback):
if exctype == KeyboardInterrupt:
print "Handler code goes here"
else:
sys.__excepthook__(exctype, value, traceback)
sys.excepthook = my_except_hook
【讨论】:
sys.excepthook原始值的sys.__excepthook__,而不是手动保存。
sys.__excepthook__ 会保留旧值。
excepthooks。
KeyboardInterrupt 引起的中断。所有其他异常仍将导致与 sys.excepthook 未更改时相同的行为。