5
は私が予期しない例外を発生させ機能があると、私はipdbでラップ:スタックトレースからローカル変数を抽出するにはどうすればよいですか?
def boom(x, y):
try:
x/y
except Exception as e:
import ipdb; ipdb.set_trace()
def main():
x = 2
y = 0
boom(x, y)
if __name__ == '__main__':
main()
私は、xとyが持っている値かを調べるために、スタックを上に移動することができます
$ python crash.py
> /tmp/crash.py(6)boom()
5 except Exception as e:
----> 6 import ipdb; ipdb.set_trace()
7
ipdb> u
> /tmp/crash.py(11)main()
10 y = 0
---> 11 boom(x, y)
12
ipdb> p y
0
しかし、デバッグ時に、私はちょうど、トップレベルのデバッガを置きたい:
def boom(x, y):
x/y
def main():
x = 2
y = 0
boom(x, y)
if __name__ == '__main__':
try:
main()
except Exception as e:
import ipdb; ipdb.set_trace()
私はトレースバックを表示することができますが、私は呼び出された関数内で変数を表示することができない:
$ python crash.py
> /tmp/crash.py(14)<module>()
12 main()
13 except Exception as e:
---> 14 import ipdb; ipdb.set_trace()
ipdb> !import traceback; traceback.print_exc(e)
Traceback (most recent call last):
File "crash.py", line 12, in <module>
main()
File "crash.py", line 8, in main
boom(x, y)
File "crash.py", line 3, in boom
x/y
ZeroDivisionError: integer division or modulo by zero
ipdb> d # I want to see what value x and y had!
*** Newest frame
例外オブジェクトは明らかにまだ例外が発生したスタックへの参照を持っています。スタックが巻き戻されていてもx
とy
にアクセスできますか?