新聞中心
今天為大家介紹如何調(diào)試Python程序。

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


咨詢(xún)
建站咨詢(xún)
