結束添加print然後執行指令碼的低效Debug方式,熟悉GDB的同學應該很容易就接受PDB。官方文檔地址:http://docs.python.org/library/pdb.html。
使用PDB的方式有兩種,其中一種是在指令碼中添加代碼,不覺得這種方式比print好在哪裡,所以這種方式此文不表。這裡我們只學習PDB的命令列使用方式。
1)進入命令列Debug模式,python -m pdb myscript.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語句在當前環境下執行;