1. 程式人生 > >Python 偵錯程式之pdb

Python 偵錯程式之pdb

https://www.cnblogs.com/xiaohai2003ly/p/8529472.html

 

Python 偵錯程式之pdb

使用PDB的方式有兩種:

1. 單步執行程式碼,通過命令 python -m pdb xxx.py 啟動指令碼,進入單步執行模式

 pdb命令列:

    1)進入命令列Debug模式,python -m pdb xxx.py

    2)h:(help)幫助

    3)w:(where)列印當前執行堆疊

    4)d:(down)執行跳轉到在當前堆疊的深一層(個人沒覺得有什麼用處)

    5)u:(up)執行跳轉到當前堆疊的上一層

    6)b:(break)新增斷點

                 b 列出當前所有斷點,和斷點執行到統計次數

                 b line_no:當前指令碼的line_no行新增斷點

                 b filename:line_no:指令碼filename的line_no行新增斷點

                 b function:在函式function的第一條可執行語句處新增斷點

    7)tbreak:(temporary break)臨時斷點

                 在第一次執行到這個斷點之後,就自動刪除這個斷點,用法和b一樣

    8)cl:(clear)清除斷點

                cl 清除所有斷點

                cl bpnumber1 bpnumber2... 清除斷點號為bpnumber1,bpnumber2...的斷點

                cl lineno 清除當前指令碼lineno行的斷點

                cl filename:line_no 清除指令碼filename的line_no行的斷點

    9)disable:停用斷點,引數為bpnumber,和cl的區別是,斷點依然存在,只是不啟用

    10)enable:啟用斷點,引數為bpnumber

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

                如果本句是函式呼叫,則s會執行到函式的第一句

    12)n:(next)執行下一條語句

                如果本句是函式呼叫,則執行函式,接著執行當前執行語句的下一條。

    13)r:(return)執行當前執行函式到結束

    14)c:(continue)繼續執行,直到遇到下一條斷點

    15)l:(list)列出原始碼

                 l 列出當前執行語句周圍11條程式碼

                 l first 列出first行周圍11條程式碼

                 l first second 列出first--second範圍的程式碼,如果second<first,second將被解析為行數

    16)a:(args)列出當前執行函式的函式

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

    18)pp expression:好看一點的p expression

    19)run:重新啟動debug,相當於restart

    20)q:(quit)退出debug

    21)j lineno:(jump)設定下條執行的語句函式

                只能在堆疊的最底層跳轉,向後重新執行,向前可直接執行到行號

    22)unt:(until)執行到下一行(跳出迴圈),或者當前堆疊結束

    23)condition bpnumber conditon,給斷點設定條件,當引數condition返回True的時候bpnumber斷點有效,否則bpnumber斷點無效

 

注意:

    1:直接輸入Enter,會執行上一條命令;

    2:輸入PDB不認識的命令,PDB會把他當做Python語句在當前環境下執行;

 

例項:

#test1.py

s = '0'
n = int(s)
print(10/n)

開啟命令列執行test1.py

python -m pdb test1.py

 

pdm定位到下一步要執行的程式碼-> s = '0',輸入命令l,就是上面的第15個命令l(list)來檢視下程式碼:

輸入命令n可以單步執行程式碼

還可以輸入  p 變數名   來檢視變數

但是這個變數所在的程式碼必須是執行過之後才能檢視,否則,會出現找不到變數的情況,如下

剛開始執行test.py,到第一行程式碼s = '0',這行程式碼實際還未執行。此時檢視變數s會提示找不到變數

 

輸入命令q結束除錯,退出程式

 2. pdb單步執行太麻煩了,所以第二種方法是import pdb 之後,直接在程式碼裡需要除錯的地方放一個pdb.set_trace(),就可以設定一個斷點, 程式會在pdb.set_trace()暫停並進入pdb除錯環境,可以用pdb 變數名檢視變數,或者c繼續執行

修改下上面的例項如下,import pdb, 添加了pdb.set_trace()到可能出錯的程式碼前面

# test1.py

import pdb


s = '0'
n = int(s)
pdb.set_trace() #執行到這裡會自動暫停
print(10/n)

執行之後,程式到斷電的下一行程式碼就暫停了