The Python Debugger Pdb
Python Debugger
pdb
The Python Debugger Pdb
可以直接在命令行中启动,调试程序
也可以写在代码中
命令行使用
可以直接在命令行指定要进行调试的程序
python -m pdb my_test.py
之后会显示当前代码执行的位置
通过输入命令进行操作
命令
命令 | 作用 |
---|---|
h(elp) | 帮助 |
w(here) | 打印当前堆栈 |
d(own)[count] | 执行跳转到当前堆栈的深 [count] 层,默认为 1 |
u(p) | 执行跳转到当前堆栈的上 [count] 层,默认为 1 |
b(reak)[ ([filename:]lineno | function) [, condition] ] |
不加参数:列出所有断点; 指定行号:(可以指定其他文件的一行) 在当前行添加断点; 指定函数:在函数的第一个可执行语句添加断点; 指定条件:当条件语句满足时断点生效 |
tbreak[ ([filename:]lineno | function) [, condition] ] | 临时断点,生效一次后自动删除,使用方法同 b(reak) |
cl(ear) |
不加参数:清除所有断点; 指定行号:(可以指定其他文件的一行) 清除当前行断点; 指定断点号:清除此断点 |
disable bpnumber [bpnumber ...] | 停用断点 |
enable bpnumber [bpnumber ...] | 激活断点 |
condition bpnumber [condition] | 为此断点设定条件 |
s(tep) | 执行下一条命令,如果是函数调用,就执行到调用函数的第一句(会进入到调用的函数内部) |
n(ext) | 执行下一条语句,如果是函数调用,就执行函数,之后执行下一条语句(不会进入调用的函数内部) |
unt(il) [lineno] | 不带参数的情况下,继续执行,直到到达行号大于当前行的行号为止。使用[lineno],继续执行直到行号大于或等于[lineno]。 |
r(eturn) | 继续执行,直至当前函数 return |
retval | 打印函数最后一次的返回值 |
run [args...] | 重新启动程序,相当于restart |
c(ont(inue)) | 继续执行,直至遇到断点 |
l(ist) |
列出当前语句周围 11 行的源码。 如果有一个参数,列出该行号周围 11 行的源码。 如果有两个参数,列出区间内的源码。 如果有两个参数,且后面的小,前面的参数为行号,后面参数为列出源码的行数。 |
longlist | ll | 列出当前函数的全部源码 |
a(rgs) | 列出当前函数的所有参数 |
whatis arg | 打印参数类型 |
p expression | 输出 expression 的值 |
pp expression | 好看一点地输出 expression 的值 |
q(uit) exit | 退出 debugger 停止执行语句 |
set_trace
set_trace() 是最常用的断点方式,放置在代码中,程序会停在断点处,输入命令 c
继续运行
示例:
import pdb
def main(i):
for i in range(i):
pdb.set_trace()
print(i)
if __name__ == '__main__':
main(10)
输出:
> /dir/test.py(7)main()
-> print(i)
(Pdb)
表示执行到 /dir/test.py
的第 7 行,main()
函数中,语句为 print(i)
breakpoint()
Python 3 中加入了内置函数 breakpoint()
可以直接调用 pdb,相当于 pdb.set_trace()
run & runeval
会在当前位置打断点,接下来会执行字符串类型的表达式
用法
run(cmd, globals=None, locals=None) 会对传入的参数执行 exec()
runeval(expr, globals=None, locals=None) 会对传入的参数执行 eval()
如果不传入参数,则默认使用全局变量(__main__.dict
)
如果要传入参数就要将全部参数以字典形式传入,使用没有传入的参数会报错
The Python Debugger Pdb的更多相关文章
- The python debugger(PDB)的简介
转自:http://www.cnblogs.com/wei-li/archive/2012/05/02/2479082.html 学习Python调试,最好的资料当然是官方文档和(pdb)help了, ...
- gdb可以调试python的pdb么
1.如题: gdb可以调试python的pdb么? 答案:可以,实验如下. 2.实验: 生成一个a.py代码文件,代码如下: import pdb a = 1 print "111" ...
- Python 调试 PDB
出处:http://blog.163.com/gjx0619@126/blog/static/12740839320114995947700/ 完整 请参考:http://docs.python.or ...
- python 用pdb调试
简单调试 Python 程序 在 Python 中也可以像 gcc/gdb 那样调试程序,只要在运行 Python 程序时引入 pdb 模块(假设要调试的程序名为 d.py): $ vi d.py ...
- python调试工具pdb
pdb是基于命令行的调试工具,非常类似gnu的gdb(调试c/c++). 命令 简写命令 作用 break b 设置断点 continue c 继续执行程序 list l 查看当前行的代码段 step ...
- Python 之pdb调试
# 调试方式一:python -m pdb test.py # 相关命令: # l 查看当前代码 # n 向下执行一行代码 # c continue继续执行代码 # b break + 行数 添加断点 ...
- 学习笔记之Python调试 - pdb
python调试神器——pdb - 软谋python https://mp.weixin.qq.com/s/w3Xw8I_zh7MFq2dx5kdQXw 优秀开发者必备技能包:Python调试器 - ...
- python使用 pdb 进行调试--- python -m pdb xxx.py 即可 和gdb使用一样
使用 pdb 进行调试 pdb 是 python 自带的一个包,为 python 程序提供了一种交互的源代码调试功能,主要特性包括设置断点.单步调试.进入函数调试.查看当前代码.查看栈片段.动态改变变 ...
- [Python] Debugger in Pycharm
From: http://blog.csdn.net/u013088062/article/details/50214459 From: http://blog.csdn.net/u013088062 ...
随机推荐
- ORA-12505
tomcat 连不上 oracle,报: java.sql.SQLException: Listener refused the connection with the following error ...
- 【PAT甲级】Public Bike Management 题解
题目描述 There is a public bike service in Hangzhou City which provides great convenience to the tourist ...
- js获取url参数值的方法总结
1.方式一:通过字符串截取的方式获取参数值: 1).函数一:获取URL中的参数名及参数值的集合 /** * [获取URL中的参数名及参数值的集合] * 示例URL:http://htmlJsTest/ ...
- linux生成多对秘钥并指定秘钥登录
1.生成秘钥对并指定秘钥对名称: ssh-keygen -t rsa -f other -C "for other" 2.将other.pub公钥添加至要免密登录的服务器 3.使用 ...
- 定时任务之SpringSchedule的注意事项
在我们现在的项目中,或多或少的都会涉及到定时任务,Spring在3.0之后引入了SpringSchedule,这让我们在使用Spring的时候,可以很容易的整合SpringSchedule.但是好用归 ...
- element UI 调整表格行高
使用element UI的table默认属性,绘制表格如下: 该表格的行高太大了,于是想调小一些. 查看官网的文档,table有几个属性, row-style:行的 style 的回调方法,也可以使用 ...
- solidity智能合约implicit conversion异常
问题场景 在使用^0.5.10版本的solidity时,如果使用this关键字会出现以下问题. 代码: require(tokenContract.balanceOf(this) >= _num ...
- 2018-8-10-win10-uwp-退出程序
原文:2018-8-10-win10-uwp-退出程序 title author date CreateTime categories win10 uwp 退出程序 lindexi 2018-08-1 ...
- kafka的主题与消费
同一个消费者组不能同时消费同一个分区的数据 不同分区可以消费同一组不同消费者 同一个消费者可以同时消费多个topicA的数据 Topic和consumer依赖zookeeper,producer不依赖
- 全栈工程师对Python面试中is和==区别的详细解说!看完真的学到了!
面试实习生的时候,当问到 is 和 == 的区别时,很多同学都答不上来,搞不清两者什么时候返回一致,什么时候返回不一致.本文我们来看一下这两者的区别. 我们先来看几个例子: a = "hel ...