亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

python的debug實用工具 pdb詳解

系統 1754 0

叨逼叨

首先,介紹一下 pdb 調試,pdb 是 python 的一個內置模塊,用于命令行來調試 Python 代碼。或許你會說,現在用 Pycharm 等編輯器來調試代碼很方便,為啥要用命令行呢?這個問題,我曾經也這么想,直到有一次,代碼必須要在 Linux 系統上跑(現在 Pycharm 也可以遠程調試代碼了,今天先不說這個)

使用介紹

如何添加斷點?

說到 debug,肯定是要添加斷點的,這里有兩種方式添加斷點:

在想要斷點代碼后添加 一行

            
pdb.set_trace()
          

若是使用這種方式,直接運行 Python 文件即可進入斷點調試。

用命令行來添加斷點

            
b line_number(代碼行數)
          

若是使用這種方式,需要 python -m pdb xxx.py 來啟動斷點調試。

常用命令

先簡單介紹一下使用命令,這里不用記住,等用到的時候回來查就行。

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

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斷點無效

舉個簡單的栗子

為了驗證一下 pdb 的用法,我寫了個簡單的 Python 代碼,如下:

            
__author__ = 'zone'
__gzh__ = '公號:zone7'
import pdb
class MyScrapy:
 urls = []
 def start_url(self, urls):
 pdb.set_trace()
 for url in urls:
 print(url)
 self.urls.append(url)
 def parse(self):
 pdb.set_trace()
 for url in self.urls:
 result = self.request_something(url)
 def request_something(self, url):
 print('requesting...')
 data = '''


 
            
            
              Title
            
            


'''
 return data
scrapy= MyScrapy()
scrapy.start_url(["http://www.zone7.cn", "http://www.zone7.cn", "http://www.zone7.cn", "http://www.zone7.cn", ])
scrapy.parse()
          

運行實例:(這里為了方便大家閱讀,我添加了中文注釋,實際運行時不會有注釋的)

            
D:workenvScriptspython.exe D:/work_test/test/pdb_test/pdb_test.py
> d:work_test	estpdb_testpdb_test.py(11)start_url()
-> for url in urls:
(Pdb) n 注釋:n(next)執行下一步
> d:work_test	estpdb_testpdb_test.py(12)start_url()
-> print(url)
(Pdb) l 注釋: l(list)列出當前代碼
 7 	 urls = []
 8 	
 9 	 def start_url(self, urls):
 10 	 pdb.set_trace()
 11 	 for url in urls:
 12 ->	 print(url)
 13 	 self.urls.append(url)
 14 	
 15 	 def parse(self):
 16 	 pdb.set_trace()
 17 	 for url in self.urls:
(Pdb) c 注釋:c(continue),繼續執行,知道遇到下一個斷點
http://www.zone7.cn
http://www.zone7.cn
http://www.zone7.cn
http://www.zone7.cn
> d:work_test	estpdb_testpdb_test.py(17)parse()
-> for url in self.urls:
(Pdb) n 注釋:n(next)執行下一步
> d:work_test	estpdb_testpdb_test.py(18)parse()
-> result = self.request_something(url)
(Pdb) l 注釋: l(list)列出當前代碼
 13 	 self.urls.append(url)
 14 	
 15 	 def parse(self):
 16 	 pdb.set_trace()
 17 	 for url in self.urls:
 18 ->	 result = self.request_something(url)
 19 	
 20 	 def request_something(self, url):
 21 	 print('requesting...')
 22 	 data = '''
 23 	
(Pdb) s 注釋: s(step)這里是進入 request_something() 函數的意思
--Call--
> d:work_test	estpdb_testpdb_test.py(20)request_something()
-> def request_something(self, url):
(Pdb) n 注釋:n(next)執行下一步
> d:work_test	estpdb_testpdb_test.py(21)request_something()
-> print('requesting...')
(Pdb) l 注釋: l(list)列出當前代碼
 16 	 pdb.set_trace()
 17 	 for url in self.urls:
 18 	 result = self.request_something(url)
 19 	
 20 	 def request_something(self, url):
 21 ->	 print('requesting...')
 22 	 data = '''
 23 	
 24 	
 25 	 
            
            
 26 	 
            
              Title
            
            
(Pdb) p url 注釋:p(print)打印出 url 變量的數據
'http://www.zone7.cn'
(Pdb) n 注釋:n(next)執行下一步
requesting...
> d:work_test	estpdb_testpdb_test.py(31)request_something()
-> '''
(Pdb) p data 注釋:p(print)打印出指定變量的數據,這里由于賦值還沒完成,所以報錯
*** NameError: name 'data' is not defined
(Pdb) n 注釋:n(next)執行下一步
> d:work_test	estpdb_testpdb_test.py(32)request_something()
-> return data
(Pdb) p data 注釋:p(print)打印出指定變量的數據
'


 
            
            
              Title
            
            



'
(Pdb) q 注釋:q(quit)退出
          

總結

按照上面的例子一套下來,基本的用法就可以學會了,關鍵還是得自己多實踐,動手操練!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲一区亚洲二区 | 欧美成人免费公开播放 | 看个毛片| 91精品国产福利尤物免费 | 亚洲乱视频 | 久草热视频在线 | 国产视频福利在线 | 免费看美女隐私的网站 | 日本亚洲欧美美色 | 免费99精品国产自在现线观看 | 日韩毛片免费看 | 亚洲欧洲一二三区机械有限公司 | 欧美a在线| 99精品国产三级在线观看 | 亚洲成人免费在线观看 | 欧美一级毛片免费看视频 | 欧美曰批人成在线观看 | 国产亚洲欧美日韩综合另类 | 91国视频在线 | 女人18一级毛片免费观看 | 欧美精品亚洲一区二区在线播放 | 中文字幕免费在线观看 | 精品无人乱码一区二区三区 | 国产亚洲人成a在线v网站 | 欧美视频 亚洲视频 | 香蕉人在线香蕉人在线 | 一级毛片观看 | 97久久免费视频 | 一级毛片免费播放 | 成人欧美视频 | 欧美成人xx免费视频 | 人人狠狠综合久久亚洲88 | 成人黄色网 | 免费高清在线影片一区 | 日韩欧美久久一区二区 | 91尤物视频在线观看 | 亚洲国产精品自产在线播放 | 一区二区三区国产 | 国产香蕉视频在线 | 亚洲欧美日韩中文字幕在线 | 久久国产精品久久精品国产 |