1 描述
pdb 是 python 自带的一个包,为 python 程序提供了一种交互的源代码调试功能,
主要特性包括设置断点、单步调试、进入函数调试、查看当前代码、查看栈片段、动态改变变量的值等
调试作用 :
可以让程序单步执行,观察中间结果
可以设定指定断点,进行特定位置观察
2 调试命令
完整命令 | 简写命令 | 描述 |
args | a | 打印当前函数的参数 |
break | b | 设置断点 |
clear | cl | 清除断点 |
condition | 无 | 设置条件断点 |
continue | c或者cont | 继续运行,知道遇到断点或者脚本结束 |
disable | 无 | 禁用断点 |
enable | 无 | 启用断点 |
help | h | 查看pdb帮助 |
ignore | 无 | 忽略断点 |
jump | j | 跳转到指定行数运行 |
list | l | 列出脚本清单 |
next | n | 执行下条语句,遇到函数不进入其内部 |
p | p | 打印变量值,也可以用print |
quit | q | 退出 pdb |
return | r | 一直运行到函数返回 |
tbreak | 无 | 设置临时断点,断点只中断一次 |
step | s | 执行下一条语句,遇到函数进入其内部 |
where | w | 查看所在的位置 |
! | 无 | 在pdb中执行语句 |
注意:
1:直接输入Enter,会执行上一条命令;
2:输入PDB不认识的命令,PDB会把他当做Python语句在当前环境下执行;
3 示例
3.1 示例1(测试代码)
1 import pdb 2 a = "aaa" 3 pdb.set_trace() 4 b = "bbb" 5 c = "ccc" 6 final = a + b + c 7 print(final)
运行
> /home/tarena/桌面/t.py(4)<module>() -> b = "bbb" (Pdb) n > /home/tarena/桌面/t.py(5)<module>() -> c = "ccc" (Pdb) > /home/tarena/桌面/t.py(6)<module>() -> final = a + b + c (Pdb) > /home/tarena/桌面/t.py(7)<module>() -> print(final) (Pdb) aaabbbccc --Return-- > /home/tarena/桌面/t.py(7)<module>()->None -> print(final) (Pdb)
开始调试:
直接运行脚本,会停留在 pdb.set_trace() 处; pdb.set_trace() 的作用:从 pdb.set_trace()位置处进入调试状态,在该语句后面的代码单步执行。
选择 n+enter 可以执行当前的 statement。在第一次按下了 n+enter 之后可以直接按 enter 表示重复执行上一条 debug 命令。
import pdb pdb.set_trace() def a(n): print(n + 1) print(n + 2) print(n + 3) print(n + 4) print(n + 5) print(n + 6) def b(n): print(‘b‘,n) a(n + 1) print("b 结束") def c(): x = 100 b(x + 100) c()
运行
> /home/tarena/桌面/t.py(4)<module>() -> def a(n): (Pdb) n > /home/tarena/桌面/t.py(12)<module>() -> def b(n): (Pdb) > /home/tarena/桌面/t.py(17)<module>() -> def c(): (Pdb) > /home/tarena/桌面/t.py(21)<module>() -> c() (Pdb) b 200 202 203 204 205 206 207 b 结束 --Return-- > /home/tarena/桌面/t.py(21)<module>()->None -> c() (Pdb)
3.2 示例2(代码调试)
详细代码
https://www.ibm.com/developerworks/cn/linux/l-cn-pythondebugger/
https://docs.python.org/3.6/library/pdb.html