python linux調試
python是動態語言,編譯器檢查不到運行時的文法問題,而這些低級問題常常造成調試效率很低。之前在linux伺服器上調試,都是通過print和異常報錯來排查,簡直弱爆了。python內建的pdb正是調試的利器。
我們先建立一個測試指令碼:Shell代碼
- touch debug.py
內容:Shell代碼
- print "hello"
-
- i = 0
- for j in range(10):
- i += j
- print i
常用命令說明:
l #查看運行到哪行代碼
n #單步運行,跳過函數
s #單步運行,可進入函數
p 變數 #查看變數值
b 行號 #斷點設定到第幾行
b #顯示所有斷點列表
cl 斷點號 #刪除某個斷點
cl #刪除所有斷點
c #跳到下一個斷點
r #return當前函數
exit #退出
更多的命令http://docs.python.org/library/pdb.html
調試過程:Shell代碼
- [co_ad2@localhost ~]$ python -m pdb debug.py
- > /home/co_ad2/debug.py(1)<module>()
- -> print "hello"
- (Pdb) l
- 1 -> print "hello"
- 2
- 3 i = 0
- 4 for j in range(10):
- 5 i += j
- 6 print i
- [EOF]
- (Pdb) n
- hello
- > /home/co_ad2/debug.py(3)<module>()
- -> i = 0
- (Pdb) n
- > /home/co_ad2/debug.py(4)<module>()
- -> for j in range(10):
- (Pdb) n
- > /home/co_ad2/debug.py(5)<module>()
- -> i += j
- (Pdb) p i
- 0
- (Pdb) p j
- 0
- (Pdb) n
- > /home/co_ad2/debug.py(4)<module>()
- -> for j in range(10):
- (Pdb) n
- > /home/co_ad2/debug.py(5)<module>()
- -> i += j
- (Pdb) p i
- 0
- (Pdb) p j
- 1
- (Pdb) n
- > /home/co_ad2/debug.py(4)<module>()
- -> for j in range(10):
- (Pdb) n
- > /home/co_ad2/debug.py(5)<module>()
- -> i += j
- (Pdb) p i
- 1
- (Pdb) p j
- 2
- (Pdb) b 6
- Breakpoint 1 at /home/co_ad2/debug.py:6
- (Pdb) c
- > /home/co_ad2/debug.py(6)<module>()
- -> print i
- (Pdb) p i
- 45
- (Pdb) n
- 45
- --Return--
- (Pdb) exit