Python 代码调试技巧
admin
2023-07-31 00:45:53
0

使用 pdb 进行调试

pdb 是 python 自带的一个包,为 python 程序提供了一种交互的源代码调试功能,主要特性包括设置断点、单步调试、进入函数调试、查看当前代码、查看栈片段、动态改变变量的值等。pdb 提供了一些常用的调试命令,详情见表 1。

表 1. pdb 常用命令
命令 解释
break 或 b 设置断点 设置断点
continue 或 c 继续执行程序
list 或 l 查看当前行的代码段
step 或 s 进入函数
return 或 r 执行代码直到从当前函数返回
exit 或 q 中止并退出
next 或 n 执行下一行
pp 打印变量的值
help 帮助

下面结合具体的实例讲述如何使用 pdb 进行调试。

清单 1. 测试代码示例

1234567 import pdb a = \”aaa\” pdb.set_trace() b = \”bbb\” c = \”ccc\” final = a + b + c print final

开始调试:直接运行脚本,会停留在 pdb.set_trace() 处,选择 n+enter 可以执行当前的 statement。在第一次按下了 n+enter 之后可以直接按 enter 表示重复执行上一条 debug 命令。

清单 2. 利用 pdb 调试

123456789101112131415161718192021222324 [root@rccpokidg2255 ~]#  python epdb1.py > /root/epdb1.py(4)?() -> b = \”bbb\” (Pdb) n > /root/epdb1.py(5)?() -> c = \”ccc\” (Pdb) > /root/epdb1.py(6)?() -> final = a + b + c (Pdb) list   1     import pdb   2     a = \”aaa\”  3     pdb.set_trace()   4     b = \”bbb\”  5     c = \”ccc\”  6  -> final = a + b + c   7     print final [EOF] (Pdb) [EOF] (Pdb) n > /root/epdb1.py(7)?() -> print final (Pdb)

退出 debug:使用 quit 或者 q 可以退出当前的 debug,但是 quit 会以一种非常粗鲁的方式退出程序,其结果是直接 crash。

清单 3. 退出 debug

1234567891011121314151617 [root@rccpokidg2255 ~]#  python epdb1.py > /root/epdb1.py(4)?() -> b = \”bbb\” (Pdb) n > /root/epdb1.py(5)?() -> c = \”ccc\” (Pdb) q Traceback (most recent call last):   File \”epdb1.py\”, line 5, in ?     c = \”ccc\”  File \”epdb1.py\”, line 5, in ?     c = \”ccc\”  File \”/usr/lib64/python2.4/bdb.py\”, line 48, in trace_dispatch     return self.dispatch_line(frame)   File \”/usr/lib64/python2.4/bdb.py\”, line 67, in dispatch_line     if self.quitting: raise BdbQuit bdb.BdbQuit

打印变量的值:如果需要在调试过程中打印变量的值,可以直接使用 p 加上变量名,但是需要注意的是打印仅仅在当前的 statement 已经被执行了之后才能看到具体的值,否则会报 NameError: 错误。

清单 4. debug 过程中打印变量

相关内容

热门资讯

Mobi、epub格式电子书如... 在wps里全局设置里有一个文件关联,打开,勾选电子书文件选项就可以了。
定时清理删除C:\Progra... C:\Program Files (x86)下面很多scoped_dir开头的文件夹 写个批处理 定...
500 行 Python 代码... 语法分析器描述了一个句子的语法结构,用来帮助其他的应用进行推理。自然语言引入了很多意外的歧义,以我们...
scoped_dir32_70... 一台虚拟机C盘总是莫名奇妙的空间用完,导致很多软件没法再运行。经过仔细检查发现是C:\Program...
65536是2的几次方 计算2... 65536是2的16次方:65536=2⁶ 65536是256的2次方:65536=256 6553...
小程序支付时提示:appid和... [Q]小程序支付时提示:appid和mch_id不匹配 [A]小程序和微信支付没有进行关联,访问“小...
pycparser 是一个用... `pycparser` 是一个用 Python 编写的 C 语言解析器。它可以用来解析 C 代码并构...
微信小程序使用slider实现... 众所周知哈,微信小程序里面的音频播放是没有进度条的,但最近有个项目呢,客户要求音频要有进度条控制,所...
Apache Doris 2.... 亲爱的社区小伙伴们,我们很高兴地向大家宣布,Apache Doris 2.0.0 版本已于...
python清除字符串里非数字... 本文实例讲述了python清除字符串里非数字字符的方法。分享给大家供大家参考。具体如下: impor...