所以我想抓住KeyboardInterrupt全球,并妥善处理它.我不想把我的整个脚本包含在一个巨大的try/except语句中,因为这听起来很糟糕.有没有办法做到这一点?
mul*_*ces 110
sys.excepthook如果你真的不想使用,你可以改变try/except.
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
Run Code Online (Sandbox Code Playgroud)
Rob*_*wie 24
如果这是一个在命令行上执行的脚本,则可以将运行时逻辑封装在一起main(),将其调用if __name__ == '__main__'并包装.
if __name__ == '__main__':
try:
main()
except KeyboardInterrupt:
print 'Killed by user'
sys.exit(0)
Run Code Online (Sandbox Code Playgroud)
mou*_*uad 12
你也可以使用这样的信号:
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)
Run Code Online (Sandbox Code Playgroud)
输出:
waiting for 10 s
^CI just clicked on CTRL-C
Run Code Online (Sandbox Code Playgroud)
注意:不要将信号与线程混合使用.
您的脚本是否具有您启动它的功能?
main()
Run Code Online (Sandbox Code Playgroud)
然后就是:
try:
main()
except:
...
Run Code Online (Sandbox Code Playgroud)
如果你没有一个main只是一个逐行运行的巨大脚本,那么你应该把它放在一个main.