当跨多行的代码抛出 Python 异常时,例如:
myfoos = [foo("bar",
"baz",
"quux",
i) for i in range(10)]
Python 将报告最后一行的行号,并显示该行的代码片段:
Traceback (most recent call last):
File "test.py", line 4, in <module>
i) for i in range(10)]
NameError: name 'foo' is not defined
有什么方法可以确定第一行是什么?有什么方法可以捕获异常并操纵 traceback对象能够报告类似这样的内容:
Traceback (most recent call last):
File "test.py", lines 1-4 in <module>
myfoos = [foo("bar",
"baz",
"quux",
i) for i in range(10)]
NameError: name 'foo' is not defined
最佳答案
找到该行的开头将非常困难。您必须解析 Python,或者深入研究已编译的字节代码。标准库中有一些用于解析Python的模块,但我可以根据经验告诉你,解释它们的输出是一门黑术。而且我也不确定编译后的字节码是否有答案......
关于Python异常回溯告诉我行在哪里结束,从哪里开始?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/291508/