中断python代码的执行
import ipdb; ipdb.set_trace()
有时(但不总是)让我进入 ipdb 而不 显示周围的代码行,即使我发出 l
命令也是如此。即,我得到类似的东西
> /path/to/file.py(58)main()
ipdb>
代替
> /path/to/file.py(58)main()
-> print('hello 2')
55 print('hello')
56 import pdb; pdb.set_trace()
57
58 -> print('hello 2')
59 print('hello 3')
ipdb>
有谁知道如何显示代码行?
编辑:如果我s
进入一个新函数(位于另一个文件中),每边都会出现一条环绕线。
最佳答案
ipdb
是 stock python 调试器的包装器 pdb所以在那些情况下 ipdb
不能显示行号 pdb
也不会能够做到这一点。
pdb
从 python 模块 linecache 获取源文本.并且有各种各样的东西可以挫败它。最明显的情况是没有 源文件。
如果您正在评估字符串,就会发生这种情况。例如可能在 eval("x+1")
中间或 exec("z=1+2")
.
按照同样的思路,您可能已经通过 exec
定义了函数您现在正在运行该功能。例如:
exec("def five(): return 5")
five()
您可能能够判断自己处于这种情况的方法是调整堆栈框架并查看调用上下文。所以当发生这种情况时,运行 up
或 bt
(回溯):
如果你看到:
(Pdb) up
> <string>(1)<module>()
<string>
事情意味着你处于这种情况。回溯可能显示如下内容:
/usr/lib/python2.7/bdb.py(400)run()
-> exec cmd in globals, locals
> <string>(1)<module>()
源可能不存在的其他方式可能是源代码已被删除,或者字节码可能是 generated all by itself ,或通过 AST。
还有另一个 Python 调试器叫做 trepan (对于 Python 3,请参阅 trepan3k )尝试很多更难找到源文本。它还尝试通过使用文件名的基本名称部分以外的内容来验证它显示的源代码是否与 Python 解释器正在运行的代码相匹配。
调试器甚至可以在没有 Python 源代码的情况下重建它!这个魔法是通过 uncompyle6 完成的.
所以显示这个,这是这个简单的 Python 程序的示例:
x = 3
eval("x+1")
exec("z=2")
现在我们运行调试器:
$ trepan3k /tmp/foo.py
(/tmp/foo.py:1): <module>
-> 1 x = 3
(trepan3k) step
(/tmp/foo.py:2 @6): <module>
-- 2 eval("x+1")
(trepan3k) step
(<string>:1): <module>
(/tmp/foo.py:2 @12): <module>
-> 2 eval("x+1")
(trepan3k) list
** No file <string> found
(trepan3k) deparse .
return x + 1
(trepan3k) step
(<string>:1 @7): <module>
(/tmp/foo.py:2 @12): <module>
<- 2 eval("x+1")
R=> 4
(trepan3k) step
(/tmp/foo.py:3 @16): <module>
-- 3 exec("z=2")
(trepan3k) list
End position changed to last line 3
1 x = 3
2 eval("x+1")
3 -> exec("z=2")
(trepan3k) step
(<string>:1): <module>
(/tmp/foo.py:3 @22): <module>
-> 3 exec("z=2")
(trepan3k) list
** No file <string> found
(trepan3k) deparse .
z = 2
如果这还不够,您还可以反汇编代码以查看。如果您碰巧知道 python 源文件在哪里,但由于某种原因调试器无法自行找到它,您可以使用 set substitute
告诉它源代码在哪里。 .
关于python ipdb 偶尔显示没有代码行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34648163/