python 调试器:
使用 pdb 进行调试
pdb 是 python 自带的一个包,为 python 程序提供了一种交互的源代码调试功能,主要特性包括设置断点、单步调试、进入函数调试、查看当前代码、查看栈片段、动态改变变量的值等。pdb 提供了一些常用的调试命令,详情见表 1。
表 1. pdb 常用命令
import
pdb
pdb.set_t
下面结合具体的实例讲述如何使用 pdb 进行调试。
清单 1. 测试代码示例
vim pdbtest.py #!/usr/bin/env python import pdb a = "aapdb" pdb.set_trace() b = "bbbaa" c = "cccaaa" final = a + b + c print final
python pdbtest.py
> /root/pdbtest.py(7)<module>()
-> b = "bbbaa"
(Pdb)
(Pdb) c
aapdbbbbaacccaaa
开始调试:直接运行脚本,会停留在 pdb.set_trace() 处,选择 n+enter 可以执行当前的 statement。在第一次按下了 n+enter 之后可以直接按 enter 表示重复执行上一条 debug 命令。
清单 2. 利用 pdb 调试
python pdbtest.py > /root/pdbtest.py(7)<module>() -> b = "bbbaa" (Pdb) list 2 3 4 import pdb 5 a = "aapdb" 6 pdb.set_trace() 7 -> b = "bbbaa" 8 c = "cccaaa" 9 final = a + b + c 10 print final [EOF] (Pdb) n > /root/pdbtest.py(8)<module>() -> c = "cccaaa" (Pdb) n > /root/pdbtest.py(9)<module>() -> final = a + b + c (Pdb) n > /root/pdbtest.py(10)<module>() -> print final (Pdb) n aapdbbbbaacccaaa --Return-- > /root/pdbtest.py(10)<module>()->None -> print final (Pdb)
退出 debug:使用 quit 或者 q 可以退出当前的 debug,但是 quit 会以一种非常粗鲁的方式退出程序,其结果是直接 crash。
race()
# 开启pdb提示
或者
try
:
(一段抛出异常的代码)
except:
import
pdb
pdb.pm() # 或者 pdb.post_mortem()
或者(输入 c 开始执行脚本)
python -mpdb script.py
在输入-计算-输出循环(注:REPL,READ-EVAL-PRINT-LOOP的缩写)环境下,可以有如下操作:
- c or continue
- q or quit
- l or list, 显示当前步帧的源码
- w or where,回溯调用过程
- d or down, 后退一步帧(注:相当于回滚)
- u or up, 前进一步帧
- (回车), 重复上一条指令
其余的几乎全部指令(还有很少的其他一些命令除外),在当前步帧上当作python代码进行解析。
如果你觉得挑战性还不够的话,可以试下smiley,-它可以给你展示那些变量而且你能使用它来远程追踪程序。
iPDB是一个极好的工具,我已经用它查出了很多匪夷所思的bug。
pip install ipdb
安装该工具,然后在你的代码中import ipdb; ipdb.set_trace()
,然后你会在你的程序运行时,获得一个很好的交互式提示。它每次执行程序的一行并且检查变量。
更好的调试器
pdb的直接替代者:
ipdb(easy_install ipdb) – 类似ipython(有自动完成,显示颜色等)
pudb(easy_install pudb) – 基于curses(类似图形界面接口),特别适合浏览源代码