我想在执行 Python 代码时拦截异常并做一些报告。主要是我想在发生异常时导出代码的命名空间。
我能做的是:
我有文件test.py
会引发异常:
for i in range(10):
if i > 5:
j
else:
i
check.py
当测试脚本作为参数传递时,将拦截异常并启动调试器的文件:
import sys, pdb
try:
__import__(sys.argv[1])
except Exception as e:
pdb.post_mortem(sys.exc_info()[2])
那很好。
inspect
此外,我可以使用模块在被调用者中找到发生异常的帧:
import sys, inspect
try:
__import__(sys.argv[1])
except Exception as e:
callee_frame_tuple = inspect.trace()[1]
print callee_frame_tuple
输出:
(<frame object at 0x00C9B260>, 'C:\\Temp\\test.py', 3, '<module>', [' j\n'], 0)
并使用它来获取有关框架的信息getargvalues()
:
import sys, inspect
try:
__import__(sys.argv[1])
except Exception as e:
callee_frame_tuple = inspect.trace()[1]
inspect.getargvalues(callee_named_tuple[0])[3]['__builtins__']['locals']()
输出:
{'__builtins__': <module '__builtin__' (built-in)>,
'__doc__': None,
'__file__': 'C:\\Temp\\check.py',
'__name__': '__main__',
'__package__': None,
'e': NameError("name 'j' is not defined",),
'inspect': <module 'inspect' from 'C:\Python27\lib\inspect.pyc'>,
'sys': <module 'sys' (built-in)>}
所以我得到了本地人check.py
而不是被调用者,test.py
尽管我使用它的框架引用作为getargvalues()
参数。
有谁知道如何获取被调用者命名空间?