我有一个捕获所有异常的函数,并且我希望能够在此函数中以字符串形式获取回溯。

到目前为止,这是行不通的:

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函数的默认值)。

10-08 11:40