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)
執行之後,程式到斷電的下一行程式碼就暫停了