總結(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í)行的第一行之前
本文接下來重點(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,不過這種方式是 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)了
針對(duì)上面的這段小程序的調(diào)試情況如下:
準(zhǔn)備測(cè)試程序
接下來使用上面介紹的第一種方式來調(diào)試 Python程序,以此來介紹 pdb常用的命令,不過在開始之前先要準(zhǔn)備好測(cè)試的程序代碼:
testFun.py
這是一個(gè)會(huì)被主模塊調(diào)用的子模塊,用于測(cè)試使用 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)前鍵值對(duì):", 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)前腳本對(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)前語句有一個(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í)就直接跳過去根本沒有被執(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í)是很簡(jiǎn)單的,文章中主要通過截圖展示運(yùn)行的效果。如果單純的看一遍文章,不出意外,會(huì)很沒有頭緒,甚至感覺截圖中的命令、輸出亂七八糟,但是如果親自動(dòng)手跟著走一遍流程,花不了一小時(shí),但是效果絕對(duì)極佳!多說一句,Python的調(diào)試器是 Pdb,可以對(duì)應(yīng)學(xué)習(xí) Linux下 C的調(diào)試器 gdb,以上就是本文全部?jī)?nèi)容,希望對(duì)大家學(xué)習(xí)與工作能有所幫助。
本文參考的相關(guān)文章如下:
《指針和字符串和字符串常量、用gdb來獲取非法內(nèi)存中的內(nèi)容》
《Linux gdb調(diào)試器用法全面解析》
《用PDB庫(kù)調(diào)試Python程序》
相關(guān)文章
詳解PyTorch手寫數(shù)字識(shí)別(MNIST數(shù)據(jù)集)
這篇文章主要介紹了詳解PyTorch手寫數(shù)字識(shí)別(MNIST數(shù)據(jù)集),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08
Python循環(huán)結(jié)構(gòu)的應(yīng)用場(chǎng)景詳解
這篇文章主要介紹了Python循環(huán)結(jié)構(gòu)的應(yīng)用場(chǎng)景詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07
Python 格式化打印json數(shù)據(jù)方法(展開狀態(tài))
今天小編就為大家分享一篇Python 格式化打印json數(shù)據(jù)方法(展開狀態(tài)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-02-02
python 阿里云oss實(shí)現(xiàn)直傳簽名與回調(diào)驗(yàn)證的示例方法
這篇文章主要介紹了python 阿里云oss實(shí)現(xiàn)直傳簽名與回調(diào)驗(yàn)證,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
將.py文件轉(zhuǎn)化為.exe文件的詳細(xì)過程
學(xué)Python那么久了,才知道自己不會(huì)把腳本編譯成可執(zhí)行exe文件,下面這篇文章主要給大家介紹了關(guān)于將.py文件轉(zhuǎn)化為.exe文件的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09
opencv導(dǎo)入頭文件時(shí)報(bào)錯(cuò)#include的解決方法
這篇文章主要介紹了opencv導(dǎo)入頭文件時(shí)報(bào)錯(cuò)#include的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07

