人生苦短 我用Python [0x02] 如何調(diào)試Python程序
今天為大家介紹如何調(diào)試Python程序。
0. 安裝基礎(chǔ)包
以Ubuntu 16.04 為例子
sudo apt-get install gdb python2.7-dbg
1. 如何調(diào)試python代碼
我們會(huì)使用python自帶的pdb模塊來調(diào)試代碼,在熟悉pdb功能前,先寫一個(gè)測(cè)試代碼 1.py
- a = 1
- b = 1
- c = a + b
- print c
使用pdb模塊靜態(tài)調(diào)試python代碼,執(zhí)行pdb 1.py返回如下
輸入 h 返回pdb的命令列表,里面包含了所有命令及其簡(jiǎn)寫,比如h是代表help
查看代碼內(nèi)容命令是list,簡(jiǎn)寫是l,其中l(wèi)ist命令的參數(shù)格式是 list [first, last],默認(rèn)情況下list會(huì)輸出文件的前11行代碼,比如我們的文件代碼只有幾行,再list的時(shí)候提示EOF文件已經(jīng)結(jié)束了,如果再想看代碼的話,可以用list 0來從開頭看起。
我們現(xiàn)在要測(cè)試斷點(diǎn)功能,b 3,代表我要在代碼第3行下一個(gè)斷點(diǎn),r是代表run把程序跑起來,然后程序會(huì)停留在我斷點(diǎn)的位置,這個(gè)時(shí)候我可以用p把a(bǔ)和b的變量值內(nèi)容打印出來,然后我再n代表next繼續(xù)運(yùn)行,然后我再打印c的變量值。
2. 如何已經(jīng)在運(yùn)行的python程序
上面講了如何調(diào)試python程序的一些基礎(chǔ)知識(shí),接下來我們要介紹的是如何調(diào)試一個(gè)已經(jīng)在運(yùn)行的python程序,比如在實(shí)際工作中,寫了一個(gè)python程序在運(yùn)行了,然后發(fā)現(xiàn)程序有異?;蛘邟熳o法響應(yīng)業(yè)務(wù)了,這個(gè)時(shí)候可以用gdb attach這個(gè)進(jìn)程,然后查看調(diào)用棧信息,從而可以獲知目前程序掛載那個(gè)地方。
先寫一個(gè)測(cè)試代碼 2.py,我們用time.sleep函數(shù)來模擬一個(gè)被掛起的程序
- import time
- time.sleep(10000)
把程序運(yùn)行起來 python 2.py 先查看已經(jīng)運(yùn)行起來2.py的pid,然后再執(zhí)行命令
- gdb python pid
- #查看當(dāng)前堆棧信息
- py-bt
- #我們可以看到,程序目前掛在time.sleep(10000)這個(gè)調(diào)用上
【本文是51CTO專欄機(jī)構(gòu)作者“睿江云EflyCloud”的原創(chuàng)文章,轉(zhuǎn)載請(qǐng)聯(lián)系原作者】
【責(zé)任編輯:xinxiaoliang TEL:(010)68476606】