【Python】: 使用 pbd 进行调试pyhon代码

1 篇文章 0 订阅

使用PDB的方式有两种:

1. 命令行

单步执行代码,通过命令 python -m pdb xxx.py 启动脚本,进入单步执行模式

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断点无效

注意:

1:直接输入Enter,会执行上一条命令;

2:输入PDB不认识的命令,PDB会把他当做Python语句在当前环境下执行;

实例:

test.py

s = '0'
n = int(s)
print(10/n)

打开命令行运行test1.py

python -m pdb test.py
> /home/jack/testgit/test.py(1)<module>()
-> s = '0'
(Pdb) l   # 显示
 1  ->	s = '0'
 2  	n = int(s)
 3  	print(10/n)
[EOF]
(Pdb) n   # 下一行
> /home/jack/testgit/test.py(2)<module>()
-> n = int(s)
(Pdb) l
 1  	s = '0'
 2  ->	n = int(s)
 3  	print(10/n)
[EOF]
(Pdb) p s  # 显示变量s
'0'
(Pdb) q    # 退出

2. 代码中设置断点

test.py

import pdb

s = '0'
n = int(s)
pdb.set_trace() #运行到这里会自动暂停
print(10/n)

运行:

python test.py

输出:

> /home/jack/testgit/test.py(5)<module>()
-> print(10/n)
(Pdb) l
  1  	import pdb
  2  	s = '0'
  3  	n = int(s)
  4  	pdb.set_trace()
  5  ->	print(10/n)
[EOF]
(Pdb) n
ZeroDivisionError: division by zero
> /home/jack/testgit/test.py(5)<module>()
-> print(10/n)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值