用Pdb調(diào)試有多種方式
使用 Pdb調(diào)試 Python的程序的方式主要是下面的三種!下面逐一介紹
命令行加-m參數(shù)
命令行啟動(dòng)目標(biāo)程序,加上-m參數(shù),這樣調(diào)用 testPdb.py的話斷點(diǎn)就是程序執(zhí)行的第一行之前
本文接下來重點(diǎn)講到的實(shí)例展示就是使用這種方式進(jìn)行調(diào)試的!
python -m pdb testPdb.py
在python交互環(huán)境調(diào)試
>>> import pdb >>> import testPdb >>> pdb.run('testPdb.test()')
代碼中插入一段程序
比較常用的,就是在程序中間插入一段程序,相對于在一般 IDE 里面打上斷點(diǎn)然后啟動(dòng) debug,不過這種方式是
hardcode
的
if __name__ == "__main__": a = 1 import pdb pdb.set_trace() b = 2 c = a + b print(c)
然后正常運(yùn)行腳本:
python testPdb.py
到了
pdb.set_trace()
那里就會(huì)定下來,然后就可以看到調(diào)試的提示符 (Pdb)了
針對上面的這段小程序的調(diào)試情況如下:
準(zhǔn)備測試程序
接下來使用上面介紹的第一種方式來調(diào)試 Python程序,以此來介紹 pdb常用的命令,不過在開始之前先要準(zhǔn)備好測試的程序代碼:
testFun.py
這是一個(gè)會(huì)被主模塊調(diào)用的子模塊,用于測試使用 Pdb調(diào)試的時(shí)候,是不是可以斷點(diǎn)從主模塊跟蹤進(jìn)入子模塊(后續(xù)有說明)
#!/usr/bin/python # -*- coding: utf-8 -*- def add(a, b): return a + b
testPdb.py
這是下面被調(diào)試的主模塊的代碼
#!/usr/bin/python # -*- coding: utf-8 -*- def sub(a, b): return a - b if __name__ == "__main__": print '' import testFun i = 0 a = 1 while(i < 100): a = testFun.add(a, 1) i = i + 1 print "累加結(jié)果:", a print "" for letter in 'Pdb': print "當(dāng)前字母:", letter print "" fruits = ['banana', 'apple', 'mango'] for fruit in fruits: print "當(dāng)前水果:", fruit print "" ret = 0 for num in range(10, 12): ret = sub(ret, num) print '循環(huán)結(jié)果:', ret print "" d = {'abc': 123, 123: "abc"} for (k,v) in d.items(): print "當(dāng)前鍵值對:", k, '-', v print ""
總結(jié)常用的命令
基礎(chǔ)命令
h(elp)命令:會(huì)打印當(dāng)前版本 Pdb可用的命令,如果要查詢某個(gè)命令,可輸入
h [command]
,例如
h l
查看 list命令
l(ist)命令:可以列出當(dāng)前將要運(yùn)行的代碼塊
斷點(diǎn)管理
b(reak):設(shè)置斷點(diǎn)
比如 b 12 就是在當(dāng)前腳本的第 9行加上斷點(diǎn)
比如 b sub 就是在當(dāng)前腳本的 sub函數(shù)定義處加斷點(diǎn)
除了可以在當(dāng)前的腳本中添加斷點(diǎn)之外,還可以在當(dāng)前腳本對其他腳本下斷點(diǎn),以上面用到的代碼為例
b testFun.add
就可以實(shí)現(xiàn)在 testFun.py腳本中的 add函數(shù)處加斷點(diǎn)
如果只用 b 就會(huì)顯示現(xiàn)有的全部斷點(diǎn)
condition bpnumber [condition]:設(shè)置條件斷點(diǎn),比如 condition 2 a==0 ,就是在第二個(gè)斷點(diǎn)出加條件 “a==0”
cl(ear):刪除斷點(diǎn),如果后面帶有參數(shù),就是清楚指定的斷點(diǎn);如果不帶參數(shù)就是清除所有的斷點(diǎn)
disable/enable:禁用/激活斷點(diǎn)
程序邏輯控制
下面展示的幾個(gè)命令,需要知道對應(yīng)的腳本的代碼和行號(hào),所以這里先截圖展示下面測試需要用到的前幾行代碼
c(ont(inue)),讓程序正常運(yùn)行,直到遇到下一個(gè)斷點(diǎn)
n(ext),讓程序運(yùn)行下一行,如果當(dāng)前語句有一個(gè)函數(shù)調(diào)用,用n是不會(huì)進(jìn)入被調(diào)用的函數(shù)體中的
下圖中展示的,當(dāng)對腳本斷點(diǎn)調(diào)試到
testFun.add(a, 1)
時(shí),繼續(xù)執(zhí)行n,并不會(huì)進(jìn)入
testFun.add(a, 1)
的函數(shù)內(nèi)部
s(tep),跟n相似,但如果當(dāng)前有一個(gè)函數(shù)調(diào)用,那么 s會(huì)進(jìn)入被調(diào)用的函數(shù)體中
下圖中展示的,當(dāng)對腳本斷點(diǎn)調(diào)試到
testFun.add(a, 1)
時(shí),繼續(xù)執(zhí)行s,會(huì)進(jìn)入
testFun.add(a, 1)
對應(yīng)的函數(shù)定義內(nèi)部,雖然
testFun.add
不是本腳本中定義的函數(shù)
j(ump),讓程序跳轉(zhuǎn)到指定的行數(shù)
假如當(dāng)前所在行是 10,注意:假如執(zhí)行了 j 20 之后,那么相當(dāng)于程序直接跳到 20行,中間的 11~19行其實(shí)就直接跳過去根本沒有被執(zhí)行到,所以如果這段代碼中有變量的聲明或?qū)ο蟮某跏蓟枰?20行及之后被用到,那么等到用到的時(shí)候就可能導(dǎo)致報(bào)錯(cuò)!
打印重要信息
a(rgs),打印當(dāng)前函數(shù)的參數(shù)。比如下圖就是展示斷點(diǎn)進(jìn)入到
testFun.add
內(nèi)部之后,打印
testFun.add
的參數(shù)
p,打印某個(gè)變量
退出調(diào)試
q,直接退出調(diào)試;或者使用 Ctrl+D的方式退出
總結(jié)
上面展示的使用 Pdb調(diào)試的過程其實(shí)是很簡單的,文章中主要通過截圖展示運(yùn)行的效果。如果單純的看一遍文章,不出意外,會(huì)很沒有頭緒,甚至感覺截圖中的命令、輸出亂七八糟,但是如果親自動(dòng)手跟著走一遍流程,花不了一小時(shí),但是效果絕對極佳!多說一句,Python的調(diào)試器是 Pdb,可以對應(yīng)學(xué)習(xí) Linux下 C的調(diào)試器 gdb,以上就是本文全部內(nèi)容,希望對大家學(xué)習(xí)與工作能有所幫助。
本文參考的相關(guān)文章如下:
《指針和字符串和字符串常量、用gdb來獲取非法內(nèi)存中的內(nèi)容》
《Linux gdb調(diào)試器用法全面解析》
《用PDB庫調(diào)試Python程序》
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

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