Windows Python解释器在Ctrl C上退出
对于我使用过的大多数
Python解释器,Ctrl C将导致解释器打印出“KeyboardInterrupt”并保持打开状态.但是,在最近在新计算机上安装时,Ctrl C导致解释器退出,这是不合需要的.
>设置signal.SIGINT处理程序仍然退出. 如果我在下面的代码段中的暂停期间按Ctrl C,则解释器保持打开状态. import time try: time.sleep(100) except KeyboardInterrupt: pass 环境:Windows 10上的Python 3.4.3
在Windows 8及更高版本上运行3.6之前的Python版本的shell提示符处,Ctrl C处理已中断.对于input和raw_input,它也会被破坏,你将获得一个EOFError而不是KeyboardInterrupt.您可以通过安装和启用win_unicode_console或升级到3.6来解决此问题
问题是Python从控制台读取的旧代码依赖于ReadFile,当Ctrl C中断读取时,将最后一个错误设置为ERROR_OPERATION_ABORTED(995).在Windows 8中,Microsoft完全重写了客户端进程如何与控制台通信.在这种情况下,他们打破了有关ReadFile行为的文档合同.没有错误,Python认为中止读取是0字节的成功读取.通常这表示文件结束(EOF),因此REPL只是退出,就像用户键入了Ctrl Z,Enter一样. ReadFile是来自任何File句柄的通用读取.还有一个专门的ReadConsole功能.这个仍然表现正常,这就是为什么win_unicode_console和3.6没有这个问题.他们调用ReadConsoleW来解决在控制台中使用全范围Unicode的单独问题,这恰好也解决了Ctrl C问题. 仅供参考,您在屏幕上看到的^ C不是由控制台(conhost.exe)或Python编写的.它实际上是由cmd.exe shell设置的CTRL_BREAK_EVENT处理程序打印的.如果从PowerShell运行Python,则不应该看到使用Ctrl Break打印的内容. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- 有没有用libgit2,libgit2sharp,Ngit用msxgit替换windows?
- Windows pip安装
- windows – 从ReplaceFile重现ERROR_UNABLE_TO_MOVE_REPLAC
- windows-server-2008-r2 – 磁盘性能低于预期
- Windows10下配置Linux下C语言开发环境
- windows – 用于映射网络驱动器的脚本
- windows – 如何防止资源管理器在信息亭设置中作为shell启动
- 名称XXX不存在于命名空间YYY(XAML VS12 Windows 8)
- windows – 什么时候应该在林中创建其他域?
- windows – 在批处理模式下运行R脚本,而不会弹出命令提示符
- active-directory – Windows域帐户遭到入侵后的
- 注册表 – Windows 8中的Sublime Text 2上下文菜
- windows – 如何将进程的stdout和stderr传递给同
- 安装Windows Server 2008一次还是XP三次?
- windows-10 – 在Windows 10 Fall Creators Upda
- 在Windows 7上签名的inno exe非常慢
- Windows – ConnectEx要求套接字“最初绑定”,但
- 在Windows上的virtualenv中安装python-ldap
- windows – 从WMI ExecQuery获取第一条记录
- microsoft-graph – 在Microsoft Graph / me / d