当我使用python -i file.py运行脚本并且收到错误消息时,我想找出该变量的值。但是,它在类内部,而不是实例。
class Foo:
def func(self):
action_dict = self.socket_resp() # a function that recieves some response from a socket.
print(action_dict['bar'])
python -i foo.py
keyError在action_dict中没有'bar'
action_dict
NameError:名称'action_dict'未定义'
如何在交互模式下获取action_dict变量的值
答案 0 :(得分:1)
是的,您可以得到它。 -i
中的例外情况将在sys.last_value
中提供。 首先 import sys
,然后将sys.last_value
保存到变量中!如果您输入错误,则该异常将永远消失!
然后,您可以导入traceback
模块并检查激活记录,其中包括所有调用帧中的局部变量!
因此我们得到:
% python3 -i file.py
Traceback (most recent call last):
File "file.py", line 6, in <module>
Foo().func()
File "file.py", line 4, in func
print(action_dict['bar'])
KeyError: 'bar'
>>> import sys
>>> exc = sys.last_value
>>> import traceback
>>> [*traceback.walk_tb(exc.__traceback__)][-1][0].f_locals
{'action_dict': {'foo': 'spam'}, 'self': <__main__.Foo object at 0x7f6aa2e6b978>}