如何从PDB导出变量?

时间:2013-02-13 17:23:59

标签: python pdb

想象一下以下场景:从IPython shell启动脚本,并在断点处调用python调试器。使用PDB命令,可以在此时分析代码和变量。但事实证明,变量的值需要进行更深入的研究。

是否可以将变量的值导出到IPython shell?

我的具体用例: 我挣扎着一个非常巨大的numpy数组,似乎没有正确的值。我知道我可以从python调试器运行任何python命令,但将变量的值保存在不同的断点并在IPython shell中使用所有这些命令会很有帮助。我正在拍摄像

这样的东西
ipdb> global var1; var1 = var
ipdb> continue
...
ipdb> global var2; var2 = var
ipdb> continue
... 
In [2]: abs(var1 - var2) # do some interesting calculations with IPython

3 个答案:

答案 0 :(得分:10)

您可以使用globals():

ipdb>__name__
'my_module'
ipdb> get_var = 'a value'
ipdb> globals()['myvar'] = get_var
ipdb> q
In [11]: my_module.myvar
Out[11]: 'a value'

这假设断点在my_module.py中设置,因此我们正在编辑模块my_moule的全局变量。

答案 1 :(得分:6)

不是一个漂亮的解决方案,但工作:

ipdb> import cPickle; f=open('/tmp/dump1','w+'); cPickle.dump(var,f); f.close()

...

ipdb> import cPickle; f=open('/tmp/dump2','w+'); cPickle.dump(var,f); f.close()

然后

In [2]: var1 = cPickle.load(open('/tmp/dump1'))
In [3]: var2 = cPickle.load(open('/tmp/dump2'))

答案 2 :(得分:2)

您需要区分不同的globals() 例如,假设我们有一个模块:mymodule.py

foo = 100
def test():
    bar = 200
    return bar

我们在pdb的控制下运行它。

>>> import pdb
>>> import mymodule
>>> foobar = 300
>>> pdb.run('mymodule.test()')
> <string>(1)<module>()
(Pdb) print foobar
300
(Pdb) print foo
*** NameError: name 'foo' is not defined
(Pdb) global foobar2; foobar2 = 301
(Pdb) print foobar2
301

在开始时,即在执行test()之前,pdb中的环境是您当前的globals()。因此定义了foobar,而未定义foo 然后我们执行test()并在bar = 200

结束时停止
-> bar = 200
(Pdb) print bar
200
(Pdb) print foo
100
(Pdb) print foobar
*** NameError: name 'foobar' is not defined
(Pdb) global foo2; foo2 = 101
(Pdb) print foo2
101
(Pdb) c
>>> 

pdb中的环境已更改。它在mymodule中使用globals()test()。因此定义了'foobar is not defined. while foo`。

我们已导出两个变量foobar2foo2。但他们生活在不同的范围内。

>>> foobar2
301
>>> mymodule.foobar2

Traceback (most recent call last):
  File "<pyshell#16>", line 1, in <module>
    mymodule.foobar2
AttributeError: 'module' object has no attribute 'foobar2'
>>> mymodule.foo2
101
>>> foo2

Traceback (most recent call last):
  File "<pyshell#18>", line 1, in <module>
    foo2
NameError: name 'foo2' is not defined

您已经找到了解决方案。但它的工作方式略有不同。