使用PDB简单调试Python程序简明指南

时间:2021-05-22

在 Python 中也可以像 gcc/gdb 那样调试程序,只要在运行 Python 程序时引入 pdb 模块(假设要调试的程序名为 d.py):
复制代码 代码如下:
$ vi d.py
#!/usr/bin/python

def main():
i, sum = 1, 0
for i in xrange(100):
sum = sum + i
print sum

if __name__ == '__main__':
main()

$ python -m pdb d.py

运行上面的命令后进入以下界面,可以输入类似 gdb 的命令来改变程序的执行流程:
复制代码 代码如下:
$ python -m pdb 1.py
> d.py(3)()
-> def main():
(Pdb)

list 显示程序的最近代码段:
复制代码 代码如下:
(Pdb) list
1 #!/usr/bin/python
2
3 ->def main():
4 i, sum = 1, 0
5 for i in xrange(100):
6 sum = sum + i
7 print sum
8
9 if __name__ == '__main__':
10 main()
[EOF]

next 或者 n 执行下一行代码:
复制代码 代码如下:
(Pdb) next
> d.py(9)()
-> if __name__ == '__main__':

用 break 在第6行设置一个断点:
复制代码 代码如下:
(Pdb) break d.py:6
Breakpoint 1 at d.py:6

(Pdb) list
1 #!/usr/bin/python
2
3 def main():
4 i, sum = 1, 0
5 ->for i in xrange(100):
6 Bsum = sum + i
7 print sum
8
9 if __name__ == '__main__':
10 main()
[EOF]

如果想在函数处设置断点:
复制代码 代码如下:
(Pdb) break d.main
d.py:3

(Pdb) list
1 #!/usr/bin/python
2
3 Bdef main():
4 ->i, sum = 1, 0
5 for i in xrange(100):
6 sum = sum + i
7 print sum
8
9 if __name__ == '__main__':
10 main()
[EOF]

还可以给断点加条件,比如设置条件只有当 sum > 50 的时候才 break:
复制代码 代码如下:
(Pdb) break d.py:6, sum > 50
Breakpoint 1 at d.py:6

如果想查看某个变量的值,可以用 pp 命令打印出来:
复制代码 代码如下:
(Pdb) step
> d.py(5)main()
-> for i in xrange(100):
(Pdb) pp sum
0

可以直接在程序里使用 pdb 模块,import pdb 后 pdb.set_trace():
复制代码 代码如下:
#!/usr/bin/python
import pdb

def main():
i, sum = 1, 0
for i in xrange(100):
sum = sum + i
pdb.set_trace()
print sum

if __name__ == '__main__':
main()

这样只要运行程序 ./d.py 就可以直接运行到 print sum 处:
复制代码 代码如下:
$ ./d.py
> d.py(9)main()
-> print sum
(Pdb)

总结

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章