夜已深...
偷吃小零食夜已深,还有什么人?没啦...
最近各种忙,结果就是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的知识文章叫醒大家!谢谢……