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