python-sys.excepthook在导入的模块中不起作用
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python-sys.excepthook在导入的模块中不起作用,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2188字,纯文字阅读大概需要4分钟。
内容图文
![python-sys.excepthook在导入的模块中不起作用](/upload/InfoBanner/zyjiaocheng/672/8180bfcf38724f399193c312c1a9467d.jpg)
我正在尝试设计一个Python程序,该程序使用日志记录模块记录所有未捕获的异常.我通过使用sys.excepthook函数覆盖默认的异常处理来做到这一点.我注意到,如果我直接从命令行运行程序,则可以正常运行,但是如果尝试导入文件,则无法正常运行.似乎sys.excepthook函数没有意识到日志记录模块.这是一个例子:
#! /usr/bin/env python2.7
import logging, sys
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
logger.addHandler(logging.FileHandler("test.log"))
print "outside of exception handler: logger = %s" % logger
def handleException(excType, excValue, traceback):
#global logger # this function doesn't work whether or not I include this line
print "inside exception handler: logger = %s" % logger
logger.error("Uncaught exception", exc_info=(excType, excValue, traceback))
sys.excepthook = handleException
logger.debug("starting")
asdf # create an exception
如果我从命令行(./loggingTest.py)运行此程序,它将正常工作.异常被记录,我看到以下输出:
outside of exception handler: logger = <logging.RootLogger object at 0x7f2022eab950>
inside exception handler: logger = <logging.RootLogger object at 0x7f2022eab950>
但是,如果我运行Python解释器并尝试导入文件(导入loggingTest),它的行为就很奇怪.异常未记录,我看到了这一点:
outside of exception handler: logger = <logging.RootLogger object at 0x7f8ab04f3ad0>
inside exception handler: logger = None
Error in sys.excepthook:
Traceback (most recent call last):
File "loggingTest.py", line 13, in handleException
logger.error("Uncaught exception", exc_info=(excType, excValue, traceback))
AttributeError: 'NoneType' object has no attribute 'error'
Original exception was:
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "loggingTest.py", line 18, in <module>
asdf # create an exception
NameError: name 'asdf' is not defined
我也许可以通过再次在sys.excepthook中导入日志记录模块来解决此问题,但我仍然很好奇:为什么会这样?
解决方法:
我将此问题报告为Python bug tracker上的错误.到目前为止,有人回应说Python 2.7和2.7.1之间肯定存在变化,他认为这是预期的行为.他建议使用类似的方法来记录所有异常:
def handleException(excType, excValue, traceback, logger=logger):
logger.error("Uncaught exception", exc_info=(excType, excValue, traceback))
sys.excepthook = handleException
内容总结
以上是互联网集市为您收集整理的python-sys.excepthook在导入的模块中不起作用全部内容,希望文章能够帮你解决python-sys.excepthook在导入的模块中不起作用所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。