利用好調(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運(yùn)行一個腳本, 舉個例子:
$ python -m pdb my_script.py
這會觸發(fā)debugger在腳本第一行指令處停止執(zhí)行。這在腳本很短時會很有幫助。你可以通過(Pdb)模式接著查看變量信息,并且逐行調(diào)試。
同時,你也可以在腳本內(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())
試下保存上面的腳本后運(yùn)行之。你會在運(yùn)行時馬上進(jìn)入debugger模式?,F(xiàn)在是時候了解下debugger模式下的一些命令了。
c
: 繼續(xù)執(zhí)行w
: 顯示當(dāng)前正在執(zhí)行的代碼行的上下文信息a
: 打印當(dāng)前函數(shù)的參數(shù)列表s
: 執(zhí)行當(dāng)前代碼行,并停在第一個能停的地方(相當(dāng)于單步進(jìn)入)n
: 繼續(xù)執(zhí)行到當(dāng)前函數(shù)的下一行,或者當(dāng)前行直接返回(單步跳過)單步跳過(n
ext)和單步進(jìn)入(s
tep)的區(qū)別在于, 單步進(jìn)入會進(jìn)入當(dāng)前行調(diào)用的函數(shù)內(nèi)部并停在里面, 而單步跳過會(幾乎)全速執(zhí)行完當(dāng)前行調(diào)用的函數(shù),并停在當(dāng)前函數(shù)的下一行。
pdb真的是一個很方便的功能,上面僅列舉少量用法,更多的命令強(qiáng)烈推薦你去看官方文檔。