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

Python 必備 debug 神器:pdb

系統(tǒng) 1657 0

使用介紹

如何添加斷點(diǎn)?

說(shuō)到 debug,肯定是要添加斷點(diǎn)的,這里有兩種方式添加斷點(diǎn):

在想要斷點(diǎn)代碼后添加 一行

pdb.set_trace()

若是使用這種方式,直接運(yùn)行 Python 文件即可進(jìn)入斷點(diǎn)調(diào)試。

用命令行來(lái)添加斷點(diǎn)

b line_number

若是使用這種方式,需要 python -m pdb xxx.py 來(lái)啟動(dòng)斷點(diǎn)調(diào)試。

常用命令

先簡(jiǎn)單介紹一下使用命令,這里不用記住,等用到的時(shí)候回來(lái)查就行。

1 進(jìn)入命令行Debug模式,python -m pdb xxx.py

2 h:(help)幫助

3 w:(where)打印當(dāng)前執(zhí)行堆棧

4 d:(down)執(zhí)行跳轉(zhuǎn)到在當(dāng)前堆棧的深一層(個(gè)人沒覺得有什么用處)

5 u:(up)執(zhí)行跳轉(zhuǎn)到當(dāng)前堆棧的上一層

6 b:(break)添加斷點(diǎn)

b 列出當(dāng)前所有斷點(diǎn),和斷點(diǎn)執(zhí)行到統(tǒng)計(jì)次數(shù)

b line_no:當(dāng)前腳本的line_no行添加斷點(diǎn)

b filename:line_no:腳本filename的line_no行添加斷點(diǎn)

b function:在函數(shù)function的第一條可執(zhí)行語(yǔ)句處添加斷點(diǎn)

7 tbreak:(temporary break)臨時(shí)斷點(diǎn)

8 cl:(clear)清除斷點(diǎn)

cl 清除所有斷點(diǎn)

cl bpnumber1 bpnumber2... 清除斷點(diǎn)號(hào)為bpnumber1,bpnumber2...的斷點(diǎn)

cl lineno 清除當(dāng)前腳本lineno行的斷點(diǎn)

cl filename:line_no 清除腳本filename的line_no行的斷點(diǎn)

9 disable:停用斷點(diǎn),參數(shù)為bpnumber,和cl的區(qū)別是,斷點(diǎn)依然存在,只是不啟用

10 enable:激活斷點(diǎn),參數(shù)為bpnumber

11 s:(step)執(zhí)行下一條命令

如果本句是函數(shù)調(diào)用,則s會(huì)執(zhí)行到函數(shù)的第一句

12 n:(next)執(zhí)行下一條語(yǔ)句

如果本句是函數(shù)調(diào)用,則執(zhí)行函數(shù),接著執(zhí)行當(dāng)前執(zhí)行語(yǔ)句的下一條。

13 r:(return)執(zhí)行當(dāng)前運(yùn)行函數(shù)到結(jié)束

14 c:(continue)繼續(xù)執(zhí)行,直到遇到下一條斷點(diǎn)

15 l:(list)列出源碼

l 列出當(dāng)前執(zhí)行語(yǔ)句周圍11條代碼

l first 列出first行周圍11條代碼

l first second 列出first--second范圍的代碼,如果second

16 a:(args)列出當(dāng)前執(zhí)行函數(shù)的函數(shù)

17 p expression:(print)輸出expression的值

18 pp expression:好看一點(diǎn)的p expression

19 run:重新啟動(dòng)debug,相當(dāng)于restart

20 q:(quit)退出debug

21 j lineno:(jump)設(shè)置下條執(zhí)行的語(yǔ)句函數(shù)

只能在堆棧的最底層跳轉(zhuǎn),向后重新執(zhí)行,向前可直接執(zhí)行到行號(hào)

22)unt:(until)執(zhí)行到下一行(跳出循環(huán)),或者當(dāng)前堆棧結(jié)束

23)condition bpnumber conditon,給斷點(diǎn)設(shè)置條件,當(dāng)參數(shù)condition返回True的時(shí)候bpnumber斷點(diǎn)有效,否則bpnumber斷點(diǎn)無(wú)效

舉個(gè)簡(jiǎn)單的栗子

為了驗(yàn)證一下 pdb 的用法,我寫了個(gè)簡(jiǎn)單的 Python 代碼,如下:

Python 必備 debug 神器:pdb_第1張圖片

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

D:\work\venv\Scripts\python.exe D:/work_test/test/pdb_test/pdb_test.py

> d:\work_test\test\pdb_test\pdb_test.py(11)start_url()

-> for url in urls:

(Pdb) n? 注釋:n(next)執(zhí)行下一步

> d:\work_test\test\pdb_test\pdb_test.py(12)start_url()

-> print(url)

(Pdb) l? 注釋: l(list)列出當(dāng)前代碼

? 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),繼續(xù)執(zhí)行,知道遇到下一個(gè)斷點(diǎn)

http://www.zone7.cn

http://www.zone7.cn

http://www.zone7.cn

http://www.zone7.cn

> d:\work_test\test\pdb_test\pdb_test.py(17)parse()

-> for url in self.urls:

(Pdb) n? 注釋:n(next)執(zhí)行下一步

> d:\work_test\test\pdb_test\pdb_test.py(18)parse()

-> result = self.request_something(url)

(Pdb) l 注釋: l(list)列出當(dāng)前代碼

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)這里是進(jìn)入 request_something() 函數(shù)的意思

--Call--

> d:\work_test\test\pdb_test\pdb_test.py(20)request_something()

-> def request_something(self, url):

(Pdb) n? 注釋:n(next)執(zhí)行下一步

> d:\work_test\test\pdb_test\pdb_test.py(21)request_something()

-> print('requesting...')

(Pdb) l 注釋: l(list)列出當(dāng)前代碼

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 變量的數(shù)據(jù)

'http://www.zone7.cn'

(Pdb) n? 注釋:n(next)執(zhí)行下一步

requesting...

> d:\work_test\test\pdb_test\pdb_test.py(31)request_something()

-> '''

(Pdb) p data? 注釋:p(print)打印出指定變量的數(shù)據(jù),這里由于賦值還沒完成,所以報(bào)錯(cuò)

*** NameError: name 'data' is not defined

(Pdb) n? 注釋:n(next)執(zhí)行下一步

> d:\work_test\test\pdb_test\pdb_test.py(32)request_something()

-> return data

(Pdb) p data? 注釋:p(print)打印出指定變量的數(shù)據(jù)

'\n\n\n? ? \n? ? Title \n\n\n\n\n'

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

總結(jié)

按照上面的例子一套下來(lái),基本的用法就可以學(xué)會(huì)了,關(guān)鍵還是得自己多實(shí)踐,今天就寫到這,還想寫一篇關(guān)于性能調(diào)試的文章,不知道這兩天有沒有時(shí)間了


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

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

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 91在线品视觉盛宴免费 | 亚洲视频在线看 | 最近更新在线中文字幕一页 | 国内揄拍国内精品久久 | 青草成人| 中文字幕福利 | 国产精品乱码高清在线观看 | 农村寡妇一级毛片免费看视频 | 操人网站| 老司机性视频 | 国产亚洲精品在天天在线麻豆 | 一区二区三区免费精品视频 | 国产精品19禁在线观看2021 | 四虎影院最新地址 | 精品免费久久久久国产一区 | 亚洲成人毛片 | 在线观看视频中文字幕 | 国产亚洲精品一区二区久久 | 一区国严二区亚洲三区 | 97人人网 | 亚洲视频网 | 亚洲天堂一区 | 伊人网站在线 | 91精品国产综合久久青草 | 久久国产精品一国产精品金尊 | 在线91精品亚洲网站精品成人 | 国产精品免费看久久久 | 欧美日韩你懂的 | 最新香蕉97超级碰碰碰碰碰久 | 国产成人成人一区二区 | 在线精品国内视频秒播 | 色婷婷激婷婷深爱五月小蛇 | 国产大片在线播放 | 手机在线精品视频 | 99热这里只有精品首页精品 | 五月婷婷之综合激情 | 国产一区免费在线观看 | 日本-区二区三区免费精品 日本热久久 | 69视频在线观看福利视频 | 精品久久香蕉国产线看观看亚洲 | 久久久久香蕉 |