首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >python : KeyboardInterrupt中的意外输出

python : KeyboardInterrupt中的意外输出
EN

Stack Overflow用户
提问于 2017-08-07 23:09:26
回答 1查看 884关注 0票数 4

运行此代码

代码语言:javascript
复制
import gevent

def f():
    while True:
        gevent.sleep(1)

if __name__ == '__main__':
    tasks = (gevent.spawn(f),)
    try:
        gevent.wait(tasks)
    except KeyboardInterrupt:
        print("KeyboardInterrupt trapped")

然后按一个Ctrl,给我输出:

代码语言:javascript
复制
$ python receiver.py 
^CKeyboardInterrupt
Tue Aug  8 00:56:04 2017
KeyboardInterrupt trapped

为什么?

似乎有人在写输出的退出时间。

如何防止第一行中的KeyboardInterrupt和第二行中的日期?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-18 10:29:37

这些消息是由gevent集线器打印的,它正在拦截正在引发的KeyboardInterrupt。通常,您将看到一个跟踪,而不是只看到KeyboardInterrupt和当前日期,但由于集线器是特殊的,您将得到该输出。

解决这个问题有两种方法:

  1. 将KeyboardInterrupt标记为无错误: gevent.get_hub().NOT_ERROR += (KeyboardInterrupt,) 使用此技巧,当KeyboardInterrupt被捕获时,集线器将不会打印任何行。这似乎是一个黑客,但它是一个短期和有效的方法,以停止输出污染。
  2. 为SIGINT注册一个信号处理程序: def处理程序(signum,frame):print('SIGINT陷波‘) sys.exit(0) signal.signal(signal.SIGINT,处理程序) SIGINT的默认信号处理程序将引发KeyboardInterrupt,但是如果您定义了自己的信号处理程序,则可以防止它并运行清理代码。 重要的是从处理程序函数中异常退出,否则对gevent.wait()的调用不会停止。您可以使用的唯一两个异常是SystemExit和GreenletExit (这是上面NOT_ERROR列表中的两个默认异常):任何其他异常都将导致that在标准错误上打印某些内容。
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45556949

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档