調(diào)試(Debugging)
利用好調(diào)試,能大大提高你捕捉代碼Bug的淫僻。大部分新人忽略了Python debugger(pdb)的重要性。 在這個章節(jié)我只會告訴你一些重要的命令壶唤,你可以從官方文檔中學(xué)習(xí)到更多雳灵。
譯者注,參考:https://docs.python.org/2/library/pdb.html Or https://docs.python.org/3/library/pdb.html
從命令行運行
你可以在命令行使用Python debugger運行一個腳本闸盔, 舉個例子:
$ python -m pdb my_script.py
這會觸發(fā)debugger在腳本第一行指令處停止執(zhí)行悯辙。這在腳本很短時會很有幫助。你可以通過(Pdb)模式接著查看變量信息迎吵,并且逐行調(diào)試躲撰。
從腳本內(nèi)部運行
同時,你也可以在腳本內(nèi)部設(shè)置斷點击费,這樣就可以在某些特定點查看變量信息和各種執(zhí)行時信息了拢蛋。這里將使用pdb.set_trace()方法來實現(xiàn)。舉個例子:
import pdb?
def make_bread():
? ? ? pdb.set_trace()
? ? ? return"I don't have time"
print(make_bread())
試下保存上面的腳本后運行之蔫巩。你會在運行時馬上進入debugger模式∽焕猓現(xiàn)在是時候了解下debugger模式下的一些命令了快压。
命令列表:
c: 繼續(xù)執(zhí)行
w: 顯示當(dāng)前正在執(zhí)行的代碼行的上下文信息
a: 打印當(dāng)前函數(shù)的參數(shù)列表
s: 執(zhí)行當(dāng)前代碼行,并停在第一個能停的地方(相當(dāng)于單步進入)
n: 繼續(xù)執(zhí)行到當(dāng)前函數(shù)的下一行垃瞧,或者當(dāng)前行直接返回(單步跳過)
單步跳過(next)和單步進入(step)的區(qū)別在于蔫劣, 單步進入會進入當(dāng)前行調(diào)用的函數(shù)內(nèi)部并停在里面, 而單步跳過會(幾乎)全速執(zhí)行完當(dāng)前行調(diào)用的函數(shù)个从,并停在當(dāng)前函數(shù)的下一行脉幢。
pdb真的是一個很方便的功能嗦锐,上面僅列舉少量用法嫌松,更多的命令強烈推薦你去看官方文檔。