调试命令
使用Python pdb 调试的方式有两种:
-
python -m pdb xxx.py
- 代码需要断点的地方增加
pdb.set_trace()
pdb命令参数:
- 进入debug模式:
python -m pdb xxx.py
- h:(help)帮助
- w:(where)打印当前执行堆栈
- d:(down)执行跳转到在当前堆栈的深一层(个人没觉得有什么用处)
- u:(up)执行跳转到当前堆栈的上一层
- b:(break)添加断点
b 列出当前所有断点,和断点执行到统计次数
b line_no:当前脚本的line_no行添加断点
b filename:line_no:脚本filename的line_no行添加断点
b function:在函数function的第一条可执行语句处添加断点
- tbreak:(temporary break)临时断点
在第一次执行到这个断点之后,就自动删除这个断点,用法和b一样
- cl:(clear)清除断点
cl 清除所有断点
cl bpnumber1 bpnumber2… 清除断点号为bpnumber1,bpnumber2…的断点
cl lineno 清除当前脚本lineno行的断点
cl filename:line_no 清除脚本filename的line_no行的断点
- disable:停用断点,参数为bpnumber,和cl的区别是,断点依然存在,只是不启用
- enable:激活断点,参数为bpnumber
- s:(step)执行下一条命令,如果本句是函数调用,则s会进入函数
- n:(next)执行下一条语句,如果本句是函数调用,则直接执行完整个函数,进行下一步操作
- r:(return)执行当前运行函数到结束
- c:(continue)继续执行,直到遇到下一条断点
- l:(list)列出源码
l 列出当前执行语句周围11条代码
l first 列出first行周围11条代码
l first second 列出first–second范围的代码,如果second<first,second将被解析为行数
- a:(args)列出当前执行函数的函数
- p expression:(print)输出expression的值
- pp expression:好看一点的p expression
- run:重新启动debug,相当于restart
- q:(quit)退出debug
- j lineno:(jump)设置下条执行的语句函数, 只能在堆栈的最底层跳转,向后重新执行,向前可直接执行到行号
- unt:(until)执行到下一行(跳出循环),或者当前堆栈结束
- condition bpnumber conditon,给断点设置条件,当参数condition返回True的时候bpnumber断点有效,否则bpnumber断点无效
注意:
- 直接输入Enter,会执行上一条命令;
- 输入PDB不认识的命令,PDB会把他当做Python语句在当前环境下执行;
实例
test.py
调试方法一:python -m pdb test.py
- 进入调试模式:
python -m pdb test.py
- 查看源码:
l
- 在函数add和print出打断点:
b add
or b 7(行号4)
- 运行并且查看参数变量:
c
print a
- 清除所有断点:
cl
- 退出调试程序:
q
调试方法二:pdb.set_trace()
上述代码我们需要在运行add函数的时候中断,进行调试。所以代码调整如下:
此时直接运行test.py