python pdb調(diào)試方法分享
import pdb
def pdb_test(arg):
for i in range(arg):
print(i)
return arg
pdb.run("pdb_test(3)")
b 函數(shù)名、行號(hào):
打斷點(diǎn),b可以查詢所有的斷點(diǎn)。
(Pdb) b pdb_test
Breakpoint 1 at c:\users\plpcc\desktop\pdbtest.py:3
(Pdb) b
Num Type Disp Enb Where
breakpoint keep yes at c:\users\plpcc\desktop\pdbtest.py:3
c:
運(yùn)行程序,直到遇到斷點(diǎn)。
(Pdb) c
> c:\users\plpcc\desktop\pdbtest.py(4)pdb_test()
-> for i in range(arg):
l:
查看斷點(diǎn)周圍的代碼
(Pdb) l
import pdb
B def pdb_test(arg):
-> for i in range(arg):
print(i)
return arg
pdb.run("pdb_test(3)")
a:
查看參數(shù)
(Pdb) a
arg = 3
s, n:
單步運(yùn)行,區(qū)別s會(huì)進(jìn)入路徑中的函數(shù),n不會(huì)進(jìn)入
p:
查看表達(dá)式的值
(Pdb) p i
condition:
條件斷點(diǎn),只有條件為true斷點(diǎn)才命中
> c:\users\plpcc\desktop\pdbtest.py(5)pdb_test()
-> print(i)
(Pdb) l
import pdb
def pdb_test(arg):
for i in range(arg):
B-> print(i)
return arg
pdb.run("pdb_test(3)")
[EOF]
(Pdb) b
Num Type Disp Enb Where
breakpoint keep yes at c:\users\plpcc\desktop\pdbtest.py:5
(Pdb) condition 2 i==1 //i==1時(shí)才觸發(fā)斷點(diǎn)2
New condition set for breakpoint 2.
(Pdb) b
Num Type Disp Enb Where
breakpoint keep yes at c:\users\plpcc\desktop\pdbtest.py:5
stop only if i==1
(Pdb) c
//i==0直接打印未斷住
> c:\users\plpcc\desktop\pdbtest.py(5)pdb_test()
-> print(i) //觸發(fā)斷點(diǎn),i==1
(Pdb) p i
bt:
查看調(diào)用堆棧
(Pdb) bt
c:\python33\lib\bdb.py(405)run()
-> exec(cmd, globals, locals)
<string>(1)<module>()
> c:\users\plpcc\desktop\pdbtest.py(5)pdb_test()
-> print(i)
r:
執(zhí)行到函數(shù)返回
(Pdb) r
--Return--
> c:\users\plpcc\desktop\pdbtest.py(6)pdb_test()->3 //代碼位置、函數(shù)返回值->3
-> return arg //代碼位置的語(yǔ)句
(Pdb) l
import pdb
def pdb_test(arg):
for i in range(arg):
print(i)
-> return arg
pdb.run("pdb_test(3)")
通過(guò)pdb.set_trace() 在代碼中指定位置嵌入一個(gè)斷點(diǎn),通常可以通過(guò)調(diào)試開(kāi)關(guān)來(lái)控制
import pdb
__DEBUG__ = True
def pdb_test(arg):
if True == __DEBUG__:
pdb.set_trace()
for i in range(arg):
print(i)
return arg
pdb_test(3)
運(yùn)行后在pdb.set_trace()位置被斷住,當(dāng)__DEBUG__ = False,代碼正常運(yùn)行
> c:\users\plpcc\desktop\pdbtest.py(8)pdb_test()
-> for i in range(arg):
(Pdb) l
__DEBUG__ = True
def pdb_test(arg):
if True == __DEBUG__:
pdb.set_trace()
-> for i in range(arg):
print(i)
return arg
pdb_test(3)
[EOF]
通過(guò)pdb.pm()進(jìn)行事后調(diào)試,可以跟蹤異常程序最后的堆載信息:
Traceback (most recent call last):
File "C:\Users\plpcc\Desktop\pdbTest.py", line 13, in <module>
pdb_test(3)
File "C:\Users\plpcc\Desktop\pdbTest.py", line 10, in pdb_test
1/0
ZeroDivisionError: division by zero
>>> import pdb
>>> pdb.pm()
> c:\users\plpcc\desktop\pdbtest.py(10)pdb_test()
-> 1/0
(Pdb) l
def pdb_test(arg):
if True == __DEBUG__:
pdb.set_trace()
for i in range(arg):
print(i)
-> 1/0
return arg
pdb_test(3)
相關(guān)文章
Python編寫合并字典并實(shí)現(xiàn)敏感目錄的小腳本
這篇文章主要介紹了Python編寫合并字典并實(shí)現(xiàn)敏感目錄的小腳本,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02Python中xlsx文件轉(zhuǎn)置操作詳解(行轉(zhuǎn)列和列轉(zhuǎn)行)
很多時(shí)候我們處理的Excel表格并不是我們想要的樣子,需要將表格的形式進(jìn)行相應(yīng)轉(zhuǎn)換后進(jìn)行數(shù)據(jù)分析操作,下面這篇文章主要給大家介紹了關(guān)于Python中xlsx文件轉(zhuǎn)置操作(行轉(zhuǎn)列和列轉(zhuǎn)行)的相關(guān)資料,需要的朋友可以參考下2022-07-07python寫文件時(shí)覆蓋原來(lái)的實(shí)例方法
這篇文章主要介紹了python寫文件時(shí)覆蓋原來(lái)的實(shí)例方法,對(duì)此有興趣的朋友們可以參考下。2020-07-07Python3.10動(dòng)態(tài)修改Windows系統(tǒng)本地IP地址
這篇文章主要介紹了Python3.10動(dòng)態(tài)修改Windows系統(tǒng)本地IP地址,需要的朋友可以參考下2023-05-05對(duì)Python 兩大環(huán)境管理神器 pyenv 和 virtualenv詳解
今天小編就為大家分享一篇對(duì)Python 兩大環(huán)境管理神器 pyenv 和 virtualenv詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-12-12Django實(shí)現(xiàn)內(nèi)容緩存實(shí)例方法
在本篇文章里小編給大家整理了關(guān)于Django實(shí)現(xiàn)內(nèi)容緩存實(shí)例方法,有需要的朋友們可以跟著學(xué)習(xí)下。2020-06-06