- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在尝试设计一个 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 解释器并尝试导入文件 (import 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 在导入的模块中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5451746/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!