搜索
您的当前位置:首页正文

Python自带又好用的代码调试工具Pdb学习笔记

来源:二三娱乐
夜已深...

夜已深,还有什么人?没啦...

偷吃小零食

最近各种忙,结果就是11点多家人都睡了,只剩下我终于有时间打开了电脑。坐在电脑前有些懵逼,不知道该干什么。想想算了,先偷吃一包儿子的小零食吧。然后,一包、两包、三包......哈哈

返璞归真

这几天项目有一个linux下部署数据库的操作,数据库使用python进行初始化安装。然后问题来了,由于linux服务器涉及安全要求,除了代码以来的Python3.6版本外不允许安装其他插件与工具,不巧的是python的代码报错了...
如果放在平时,代码报错编辑器下debug,分分钟解决。可Linux环境下怎么处理?如果允许安装第三方模块,PySnooper其实是个比较好的选择。可悲的是安全不允许啊...
其实Python,自带了一个debug的工具 pdb。说实话,这模块跟IDE下debug比,相差十万八千里,但有时候能实现功能的东西就是好东西!

pdb学习

pdb为Python程序定义了一个交互式源代码调试器。它支持在源代码行级别设置(条件)断点和单步执行,检查堆栈帧,源代码列表以及在任何堆栈帧的上下文中评估任意Python代码。它还支持事后调试,可以在程序控制下调用。

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

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<first,second将被解析为行数

16)a:(args)列出当前执行函数的函数
17)p expression:(print)输出expression的值
18)pp expression:好看一点的p expression
19)run:重新启动debug,相当于restart
20)q:(quit)退出debug
21)j lineno:(jump)设置下条执行的语句函数

  • 只能在堆栈的最底层跳转,向后重新执行,向前可直接执行到行号

22)unt:(until)执行到下一行(跳出循环),或者当前堆栈结束
23)condition bpnumber conditon,给断点设置条件,当参数condition返回True的时候bpnumber断点有效,否则bpnumber断点无效

代码调试

首先我们来准备一份调试代码:

# -*- coding: utf-8 -*-
# @Author   : 王翔
# @WeChat   : King_Uranus
# @公众号    : 清风Python
# @Date     : 2019/9/8 23:08
# @Software : PyCharm
# @version  :Python 3.7.3
# @File     : ReadFile.py


def change(a, b):
    for i in range(a):
        print(i)
    return a + b


x = 10
y = 1
result = change(x, y)
启动调试
# 输入命令行
python -m pdb ReadFile.py
# 启动调试
> d:\codes_repository\python\pythontests\39.readfile\readfile.py(11)<module>()
-> def change(a, b):
# 展示代码,可以看到11行的当前代码停留位置
(Pdb) ll
  1     # -*- coding: utf-8 -*-
  2     # @Author   : 王翔
  3     # @WeChat   : King_Uranus
  4     # @公众号    : 清风Python
  5     # @Date     : 2019/9/8 23:08
  6     # @Software : PyCharm
  7     # @version  :Python 3.7.3
  8     # @File     : ReadFile.py
  9
 10
 11  -> def change(a, b):
 12         for i in range(a):
 13             print(i)
 14         return a + b
 15
 16
 17     x = 10
 18     y = 1
 19     result = change(x, y)
# 在19行 13行设置断点
(Pdb) b 19
Breakpoint 1 at d:\codes_repository\python\pythontests\39.readfile\readfile.py:19
(Pdb) b 13
Breakpoint 2 at d:\codes_repository\python\pythontests\39.readfile\readfile.py:13
# 再次看到存在B的两个设置断点位置
(Pdb) ll
  1     # -*- coding: utf-8 -*-
  2     # @Author   : 王翔
  3     # @WeChat   : King_Uranus
  4     # @公众号    : 清风Python
  5     # @Date     : 2019/9/8 23:08
  6     # @Software : PyCharm
  7     # @version  :Python 3.7.3
  8     # @File     : ReadFile.py
  9
 10
 11  -> def change(a, b):
 12         for i in range(a):
 13 B           print(i)
 14         return a + b
 15
 16
 17     x = 10
 18     y = 1
 19 B   result = change(x, y)
# 跳转至第一个断点位置
(Pdb) c
> d:\codes_repository\python\pythontests\39.readfile\readfile.py(19)<module>()
-> result = change(x, y)
# 通过P +变量查看变量值
(Pdb) p x
10
(Pdb) p y
1
# 继续执行
(Pdb) c
> d:\codes_repository\python\pythontests\39.readfile\readfile.py(13)change()
-> print(i)
# 通过多次调用查看变量值
(Pdb) p i
0
(Pdb) c
0
> d:\codes_repository\python\pythontests\39.readfile\readfile.py(13)change()
-> print(i)
(Pdb) c
1
> d:\codes_repository\python\pythontests\39.readfile\readfile.py(13)change()
-> print(i)
(Pdb) p i
2
# 退出调试
(Pdb) q

以上就是基础的pdb代码调试方式了,如果大家之后也遇到需要临时调试的场景,可以尝试这种交互式的调试方式。即便不如IDE好用,但艺多不压身,多学一个模块好处多多!

The End

OK,今天的内容就到这里,如果觉得内容对你有所帮助,欢迎点击文章右下角的“在看”。
期待你关注我的公众号清风Python,如果觉得不错,希望能动动手指转发给你身边的朋友们。
希望每周一至五清晨的7点10分,都能让清风Python的知识文章叫醒大家!谢谢……

清风Python
Top