问题描述
我正在寻找一种简单 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 (将#修改为@)