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