總結(jié)用Pdb庫(kù)調(diào)試Python的方式及常用的命令
用Pdb調(diào)試有多種方式
使用 Pdb調(diào)試 Python的程序的方式主要是下面的三種!下面逐一介紹
命令行加-m參數(shù)
命令行啟動(dòng)目標(biāo)程序,加上-m參數(shù),這樣調(diào)用 testPdb.py的話斷點(diǎn)就是程序執(zhí)行的第一行之前
本文接下來(lái)重點(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()')
代碼中插入一段程序
比較常用的,就是在程序中間插入一段程序,相對(duì)于在一般 IDE 里面打上斷點(diǎn)然后啟動(dòng) debug,不過(guò)這種方式是 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ì)定下來(lái),然后就可以看到調(diào)試的提示符 (Pdb)了
針對(duì)上面的這段小程序的調(diào)試情況如下:
準(zhǔn)備測(cè)試程序
接下來(lái)使用上面介紹的第一種方式來(lái)調(diào)試 Python程序,以此來(lái)介紹 pdb常用的命令,不過(guò)在開(kāi)始之前先要準(zhǔn)備好測(cè)試的程序代碼:
testFun.py
這是一個(gè)會(huì)被主模塊調(diào)用的子模塊,用于測(cè)試使用 Pdb調(diào)試的時(shí)候,是不是可以斷點(diǎn)從主模塊跟蹤進(jìn)入子模塊(后續(xù)有說(shuō)明)
#!/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)前鍵值對(duì):", k, '-', v print ""
總結(jié)常用的命令
基礎(chǔ)命令
h(elp)命令:會(huì)打印當(dāng)前版本 Pdb可用的命令,如果要查詢(xún)某個(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)前腳本對(duì)其他腳本下斷點(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è)命令,需要知道對(duì)應(yīng)的腳本的代碼和行號(hào),所以這里先截圖展示下面測(cè)試需要用到的前幾行代碼
c(ont(inue)),讓程序正常運(yùn)行,直到遇到下一個(gè)斷點(diǎn)
n(ext),讓程序運(yùn)行下一行,如果當(dāng)前語(yǔ)句有一個(gè)函數(shù)調(diào)用,用n是不會(huì)進(jìn)入被調(diào)用的函數(shù)體中的
下圖中展示的,當(dāng)對(duì)腳本斷點(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)對(duì)腳本斷點(diǎn)調(diào)試到 testFun.add(a, 1)
時(shí),繼續(xù)執(zhí)行s,會(huì)進(jìn)入 testFun.add(a, 1)
對(duì)應(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í)就直接跳過(guò)去根本沒(méi)有被執(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)試的過(guò)程其實(shí)是很簡(jiǎn)單的,文章中主要通過(guò)截圖展示運(yùn)行的效果。如果單純的看一遍文章,不出意外,會(huì)很沒(méi)有頭緒,甚至感覺(jué)截圖中的命令、輸出亂七八糟,但是如果親自動(dòng)手跟著走一遍流程,花不了一小時(shí),但是效果絕對(duì)極佳!多說(shuō)一句,Python的調(diào)試器是 Pdb,可以對(duì)應(yīng)學(xué)習(xí) Linux下 C的調(diào)試器 gdb,以上就是本文全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)與工作能有所幫助。
本文參考的相關(guān)文章如下:
《指針和字符串和字符串常量、用gdb來(lái)獲取非法內(nèi)存中的內(nèi)容》
《Linux gdb調(diào)試器用法全面解析》
《用PDB庫(kù)調(diào)試Python程序》
相關(guān)文章
新版pycharm配置運(yùn)行參數(shù)的教程/pycharm2023
這篇文章主要介紹了新版pycharm配置運(yùn)行參數(shù)的教程/pycharm2023,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01Python實(shí)現(xiàn)動(dòng)態(tài)柱狀圖的繪制
這篇文章主要為大家詳細(xì)介紹了Python實(shí)現(xiàn)動(dòng)態(tài)柱狀圖的繪制的相關(guān)資料,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)與借鑒價(jià)值,需要的可以參考一下2022-12-12Python將阿拉伯?dāng)?shù)字轉(zhuǎn)換為羅馬數(shù)字的方法
這篇文章主要介紹了Python將阿拉伯?dāng)?shù)字轉(zhuǎn)換為羅馬數(shù)字的方法,涉及Python字符串轉(zhuǎn)換及流程控制的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07python學(xué)習(xí)pymongo模塊的使用方法
這篇文章主要介紹了python學(xué)習(xí)pymongo模塊的使用方法,pymongo模塊是python操作mongo數(shù)據(jù)的第三方模塊,總結(jié)一下常用到的簡(jiǎn)單用,需要的小伙伴可以參考一下2022-09-09Python 通過(guò)pip安裝Django詳細(xì)介紹
這篇文章主要介紹了Python 通過(guò)pip安裝Django詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2017-04-04Python實(shí)現(xiàn)批量梯度下降法(BGD)擬合曲線
這篇文章主要介紹了Python實(shí)現(xiàn)批量梯度下降法(BGD)擬合曲線,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04Python?matplotlib調(diào)整坐標(biāo)軸位置、標(biāo)簽位置和標(biāo)簽方向以及X軸刻度標(biāo)簽位置
我們?cè)谟胢atplotlib繪制圖的時(shí)候總是有各種需求,下面這篇文章主要給大家介紹了關(guān)于Python?matplotlib調(diào)整坐標(biāo)軸位置、標(biāo)簽位置和標(biāo)簽方向以及X軸刻度標(biāo)簽位置的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04