将Python异常信息转换为字符串以进行记录

前端之家收集整理的这篇文章主要介绍了将Python异常信息转换为字符串以进行记录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我尝试在Python 2.5中记录异常,但我不能这样做.所有格式化功能都不是我想要的.

我想出了这个:

def logexception(type,value,traceback):
  print traceback.format_exception(type,traceback)

sys.excepthook = logexception

但是在调用时它会因为参数错误而失败,尽管根据文档它应该有效.任何人都知道这个问题是什么或有其他插入式解决方案?

最佳答案
为什么traceback参数有一个format_exception方法就像traceback模块中的函数一样,它的名称正在篡夺,如果它有一个,为什么该方法需要调用它的同一个对象作为最后一个参数传入?

我怀疑你只是想给第三个参数一个不同的名字,以免隐藏回溯模块,说:

import sys
import traceback

def logexception(type,tb):
  print traceback.format_exception(type,tb)

sys.excepthook = logexception

而事情应该会好得多.

猜你在找的Python相关文章