我有一个捕获所有异常的函数,并且我希望能够在此函数中以字符串形式获取回溯。
到目前为止,这是行不通的:
def handle_errors(error_type, error_message, error_traceback):
"""catch errors"""
import traceback
error = {}
error['type'] = error_type.__name__
error['message'] = str(error_message)
error['file'] = os.path.split(error_traceback.tb_frame.f_code.co_filename)[1]
error['line'] = error_traceback.tb_lineno
error['traceback'] = repr(traceback.print_tb(error_traceback))
### finalise error handling and exit ###
sys.excepthook = handle_errors
这是
error['traceback']
行,这是错误的。我什至需要使用traceback
模块吗?根据this other vaguely similar question,我尝试了:
error['traceback'] = repr(error_traceback.print_exc())
...但这会导致错误:
Error in sys.excepthook:
Traceback (most recent call last):
File "xxxxxxxxxxx", line 54, in handle_errors
error['traceback'] = repr(error_traceback.print_exc())
AttributeError: 'traceback' object has no attribute 'print_exc'
最佳答案
使用 traceback.format_tb()
而不是print_tb()
来获取格式化的堆栈跟踪(作为行列表):
error['traceback'] = ''.join(traceback.format_tb(error_traceback))
print_tb()
直接打印回溯,这就是为什么要得到None
的原因(这是任何不显式返回任何内容的Python函数的默认值)。