python的debug实用工具 pdb详解
叨逼叨
首先,介绍一下pdb调试,pdb是python的一个内置模块,用于命令行来调试Python代码。或许你会说,现在用Pycharm等编辑器来调试代码很方便,为啥要用命令行呢?这个问题,我曾经也这么想,直到有一次,代码必须要在Linux系统上跑(现在Pycharm也可以远程调试代码了,今天先不说这个)
使用介绍
如何添加断点?
说到debug,肯定是要添加断点的,这里有两种方式添加断点:
在想要断点代码后添加一行
pdb.set_trace()
若是使用这种方式,直接运行Python文件即可进入断点调试。
用命令行来添加断点
bline_number(代码行数)
若是使用这种方式,需要python-mpdbxxx.py来启动断点调试。
常用命令
先简单介绍一下使用命令,这里不用记住,等用到的时候回来查就行。
1进入命令行Debug模式,python-mpdbxxx.py
2h:(help)帮助
3w:(where)打印当前执行堆栈
4d:(down)执行跳转到在当前堆栈的深一层(个人没觉得有什么用处)
5u:(up)执行跳转到当前堆栈的上一层
6b:(break)添加断点
- b列出当前所有断点,和断点执行到统计次数
- bline_no:当前脚本的line_no行添加断点
- bfilename:line_no:脚本filename的line_no行添加断点
- bfunction:在函数function的第一条可执行语句处添加断点
7tbreak:(temporarybreak)临时断点
在第一次执行到这个断点之后,就自动删除这个断点,用法和b一样
8cl:(clear)清除断点
- cl清除所有断点
- clbpnumber1bpnumber2...清除断点号为bpnumber1,bpnumber2...的断点
- cllineno清除当前脚本lineno行的断点
- clfilename:line_no清除脚本filename的line_no行的断点
9disable:停用断点,参数为bpnumber,和cl的区别是,断点依然存在,只是不启用
10enable:激活断点,参数为bpnumber
11s:(step)执行下一条命令
如果本句是函数调用,则s会执行到函数的第一句
12n:(next)执行下一条语句
如果本句是函数调用,则执行函数,接着执行当前执行语句的下一条。
13r:(return)执行当前运行函数到结束
14c:(continue)继续执行,直到遇到下一条断点
15l:(list)列出源码
- l列出当前执行语句周围11条代码
- lfirst列出first行周围11条代码
- lfirstsecond列出first--second范围的代码,如果second
16a:(args)列出当前执行函数的函数
17pexpression:(print)输出expression的值
18ppexpression:好看一点的pexpression
19run:重新启动debug,相当于restart
20q:(quit)退出debug
21jlineno:(jump)设置下条执行的语句函数
只能在堆栈的最底层跳转,向后重新执行,向前可直接执行到行号
22)unt:(until)执行到下一行(跳出循环),或者当前堆栈结束
23)conditionbpnumberconditon,给断点设置条件,当参数condition返回True的时候bpnumber断点有效,否则bpnumber断点无效
举个简单的栗子
为了验证一下pdb的用法,我写了个简单的Python代码,如下:
__author__='zone' __gzh__='公号:zone7' importpdb classMyScrapy: urls=[] defstart_url(self,urls): pdb.set_trace() forurlinurls: print(url) self.urls.append(url) defparse(self): pdb.set_trace() forurlinself.urls: result=self.request_something(url) defrequest_something(self,url): print('requesting...') data='''Title