如何将异常堆栈跟踪重定向到文件?

问题描述

我正在寻找一种简单 1 方法将堆栈跟踪重定向一个文件,这些堆栈跟踪通常在引发异常时发送到 stderr

有没有办法做到这一点?

重要提示我对 Python 3.x 和 Python 2.x(或至少 2.7.x)的这个问题的答案很感兴趣。


我认为将所需的输出流分配给 sys.stderr 就足够了,但这不起作用。

例如,如果运行下面的脚本,失败断言的回溯仍然会转到 stderr(即到终端)。相反,print 语句的输出会转到指定的文件

# NB: requires Python 3

import sys
import contextlib

mystderr_path = sys.argv[1] if len(sys.argv) > 1 else 'mystderr.txt'

with open(mystderr_path,'w') as mystderr:

    with contextlib.redirect_stderr(mystderr):

        print('written by print()',file=sys.stderr)

        assert False,'redirection test'

1 更具体地说,如果可能的话,我想避免使用 logging 模块及其所有的 javaesque 复杂性。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)