调试命令

使用Python pdb 调试的方式有两种:

  1. ​python -m pdb xxx.py​
  2. 代码需要断点的地方增加​​pdb.set_trace()​

pdb命令参数:

  1. 进入debug模式:​​python -m pdb xxx.py​
  2. h:(help)帮助
  3. w:(where)打印当前执行堆栈
  4. d:(down)执行跳转到在当前堆栈的深一层(个人没觉得有什么用处)
  5. u:(up)执行跳转到当前堆栈的上一层
  6. b:(break)添加断点

b 列出当前所有断点,和断点执行到统计次数
b line_no:当前脚本的line_no行添加断点
b filename:line_no:脚本filename的line_no行添加断点
b function:在函数function的第一条可执行语句处添加断点

  1. tbreak:(temporary break)临时断点

在第一次执行到这个断点之后,就自动删除这个断点,用法和b一样

  1. cl:(clear)清除断点

cl 清除所有断点
cl bpnumber1 bpnumber2… 清除断点号为bpnumber1,bpnumber2…的断点
cl lineno 清除当前脚本lineno行的断点
cl filename:line_no 清除脚本filename的line_no行的断点

  1. disable:停用断点,参数为bpnumber,和cl的区别是,断点依然存在,只是不启用
  2. enable:激活断点,参数为bpnumber
  3. s:(step)执行下一条命令,如果本句是函数调用,则s会进入函数
  4. n:(next)执行下一条语句,如果本句是函数调用,则直接执行完整个函数,进行下一步操作
  5. r:(return)执行当前运行函数到结束
  6. c:(continue)继续执行,直到遇到下一条断点
  7. l:(list)列出源码

l 列出当前执行语句周围11条代码
l first 列出first行周围11条代码
l first second 列出first–second范围的代码,如果second<first,second将被解析为行数

  1. a:(args)列出当前执行函数的函数
  2. p expression:(print)输出expression的值
  3. pp expression:好看一点的p expression
  4. run:重新启动debug,相当于restart
  5. q:(quit)退出debug
  6. j lineno:(jump)设置下条执行的语句函数, 只能在堆栈的最底层跳转,向后重新执行,向前可直接执行到行号
  7. unt:(until)执行到下一行(跳出循环),或者当前堆栈结束
  8. condition bpnumber conditon,给断点设置条件,当参数condition返回True的时候bpnumber断点有效,否则bpnumber断点无效

注意:

  • 直接输入Enter,会执行上一条命令;
  • 输入PDB不认识的命令,PDB会把他当做Python语句在当前环境下执行;

实例

test.py

def add(a,b):
return a + b;


print add(10,20);
调试方法一:​​python -m pdb test.py​
  1. 进入调试模式:​​python -m pdb test.py​
  2. Python 调试器 pdb_调试


  3. 查看源码:​​l​
  4. Python 调试器 pdb_函数调用_02


  5. 在函数add和print出打断点:​​b add​​​ or ​​b 7(行号4)​
  6. Python 调试器 pdb_python_03


  7. 运行并且查看参数变量:​​c​​​ ​​print a​
  8. Python 调试器 pdb_函数调用_04


  9. 清除所有断点:​​cl​
  10. Python 调试器 pdb_调试_05


  11. 退出调试程序:​​q​
调试方法二:​​pdb.set_trace()​

上述代码我们需要在运行add函数的时候中断,进行调试。所以代码调整如下:

import pdb

def add(a,b):
pdb.set_trace();
return a + b;


print add(10,20);

此时直接运行test.py

Python 调试器 pdb_pdb_06