使用PDB的方式有兩種:python
1. 單步執行代碼,經過命令 python -m pdb xxx.py 啓動腳本,進入單步執行模式express
pdb命令行:函數
1)進入命令行Debug模式,python -m pdb xxx.pyui
2)h:(help)幫助spa
3)w:(where)打印當前執行堆棧命令行
4)d:(down)執行跳轉到在當前堆棧的深一層(我的沒以爲有什麼用處)debug
5)u:(up)執行跳轉到當前堆棧的上一層3d
6)b:(break)添加斷點調試
b 列出當前全部斷點,和斷點執行到統計次數rest
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)
運行以後,程序到斷電的下一行代碼就暫停了