pdb是ptyhon内置的一个调试库,为 python 程序提供了一种交互的源代码调试功能,主要特性包括设置断点、单步调试、进入函数调试、查看当前代码、查看栈片段、动态改变变量的值等。
实际工作过程中都是采用linux远程ssh模式,无法可视化界面,那么调试技巧就是pdb。
pdb调试常见命令:
示例代码:
def test(x):
x = x + 1
return x
def test_debug():
print('start')
temp = 'my is str'
print('ok')
res = test(temp)
print('end')
test_debug()
这段代码很简单,当我们执行test_debug()时,会执行test_debug函数并在该函数中调用另一个函数test(),test函数接收一个参数x并计算x+1的值传出。很明显传进去的参数temp是str,所以当执行上面一段代码时一定会报错.
运行结果:
接下来开始使用pdb开始调试。
上图可以看到运行代码后,pdb的调试器控制台将从放置set_trace()的位置开始等待我们的命令,并且箭头标记指向pdb接下来要运行的行。
接下来再使用pdb中常用命令:
在弹出的文本框中输入n即可执行该行,并且箭头将指向下一行即将执行的代码。目前还没有到报错的位置,继续使用n或者直接回车重复执行上一个命令。
使用p打印变量值,在Pdb中可以使用p + 变量名来查看变量值,比如查看变量temp的值;使用l查看上下行代码,在Pdb中可以使用l查看当前行上下几行代码.
使用s进入子函数,来到出错的这一行,之所以报错就是传进去变量出了问题,因此可以在pdb交互行中使用s来进入子函数test().
使用r执行函数直到结束,在pdb中可以使用r来执行当前运行函数到结束
使用c停止调试并继续运行,现在我们修改相关代码完成调试,可以使用c命令继续执行命令,当然也可以输入q直接退出调试界面.
pdb用法总结:
# 导入
import pdb
# 设置断点
pdb.set_trace()
# -------------------
# 断点命令
p + 变量名 # 打印变量 或者直接变量名
n # 执行下一行
s # 进入函数
r # 执行函数到结束
c # 停止调试并继续运行
q # 退出调试
# enter 重复上一次命令
补充:
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的第一条可执行语句处添加断点
7)tbreak:(temporary break)临时断点
在第一次执行到这个断点之后,就自动删除这个断点,用法和b一样
8)cl:(clear)清除断点
cl 清除所有断点
cl bpnumber1 bpnumber2... 清除断点号为bpnumber1,bpnumber2...的断点
cl lineno 清除当前脚本lineno行的断点
cl filename:line_no 清除脚本filename的line_no行的断点
9)disable:停用断点,参数为bpnumber,和cl的区别是,断点依然存在,只是不启用
10)enable:激活断点,参数为bpnumber
11)s:(step)执行下一条命令
如果本句是函数调用,则s会执行到函数的第一句
12)n:(next)执行下一条语句
如果本句是函数调用,则执行函数,接着执行当前执行语句的下一条。
13)r:(return)执行当前运行函数到结束
14)c:(continue)继续执行,直到遇到下一条断点
15)l:(list)列出源码
l 列出当前执行语句周围11条代码
l first 列出first行周围11条代码
l first second 列出first--second范围的代码,如果second
关注
打赏
最近更新
- 深拷贝和浅拷贝的区别(重点)
- 【Vue】走进Vue框架世界
- 【云服务器】项目部署—搭建网站—vue电商后台管理系统
- 【React介绍】 一文带你深入React
- 【React】React组件实例的三大属性之state,props,refs(你学废了吗)
- 【脚手架VueCLI】从零开始,创建一个VUE项目
- 【React】深入理解React组件生命周期----图文详解(含代码)
- 【React】DOM的Diffing算法是什么?以及DOM中key的作用----经典面试题
- 【React】1_使用React脚手架创建项目步骤--------详解(含项目结构说明)
- 【React】2_如何使用react脚手架写一个简单的页面?