国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

使用Python中PDB模塊中的命令來調試Python代碼的教程

2019-11-25 17:53:47
字體:
來源:轉載
供稿:網友

你有多少次陷入不得不更改別人代碼的境地?如果你是一個開發團隊的一員,那么你遇到上述境地的次數比你想要的還要多。然而,Python中有一個整潔的調試特性(像其他大多數語言一樣),在這種情況下使用非常方便。本文是一篇快速教程,希望它能讓你的編碼生活更加容易。
1. 一個混亂的程序

出于本教程的目的,讓我們研究一下下面的簡單程序。

這個程序接收兩個命令行參數,然后執行加法和減法操作。

(假設用戶輸入的是有效值,因此代碼中我們沒有進行錯誤處理。)
 

import sysdef add(num1=0, num2=0):  return int(num1) + int(num2)def sub(num1=0, num2=0):  return int(num1) - int(num2)def main():  #Assuming our inputs are valid numbers  print sys.argv  addition = add(sys.argv[1], sys.argv[2])  print addition  subtraction = sub(sys.argv[1], sys.argv[2])  print subtractionif __name__ == '__main__':  main()

2. PDB

Python提供了一個有用的模塊PDB,它實際上是一個交互式源代碼調試器。

你需要下面的兩行代碼來使用此模塊。
 

import pdbpdb.set_trace()

看一下我們修改過的程序,里面包含了一些斷點。
 

import pdbimport sysdef add(num1=0, num2=0):  return int(num1) + int(num2)def sub(num1=0, num2=0):  return int(num1) - int(num2)def main():  #Assuming our inputs are valid numbers  print sys.argv  pdb.set_trace() # <-- Break point added here  addition = add(sys.argv[1], sys.argv[2])  print addition  subtraction = sub(sys.argv[1], sys.argv[2])  print subtractionif __name__ == '__main__':  main()

3. 程序執行觸發調試器

一旦你設置好斷點以后,你就可以像平時一樣執行程序。
 

python debugger.py 1 2

程序將會在遇到的第一個斷點處停止執行。
 

['debugger.py']> /Users/someuser/debugger.py(15)main()-> addition = add(sys.argv[1], sys.argv[2])(Pdb)

我們在第14行設置了一個斷點,所以我們能看到將要執行的下一行是第15行。可以看到,在執行到第15行之前程序已經停止。

在這里我們有幾個選項,讓我們在下面步驟中看看一些調試指令。
4. 下一行->n

在你的調試器提示中,輸入n運行到下一行。
 

> /Users/someuser/debugger.py(14)main()-> addition = add(sys.argv[1], sys.argv[2])(Pdb) n> /Users/someuser/debugger.py(15)main()-> print addition

這會執行當前行代碼,并準備執行下一行。

我們可以使用n來逐行執行整個程序,但這其實沒有什么用處。

可能你已經看到,PDB實際上并沒有進入我們的add函數中。下面,就讓我們看看其他幾個令調試更加有趣的選項。

    注意:
    一個更酷的特性是你可以單擊回車鍵來執行以前的命令(在本例中只要指令n)。

5. 打印->p

下面,我們再次開始調試程序。(你可以通過單擊c使PDB跳到末尾或者直到下一個斷點,因為程序中我們并沒有其他的斷點了,所有程序將會執行完成。)
 

['debugger.py', '1', '2']> /Users/someuser/debugger.py(14)main()-> addition = add(sys.argv[1], sys.argv[2])(Pdb)

現在,如果我們想知道sys.argv中包含什么內容,我們可以輸入以下內容:
 

-> addition = add(sys.argv[1], sys.argv[2])(Pdb) p sys.argv['debugger.py', '1', '2'](Pdb) p sys.argv[1]'1'(Pdb)

使用這種方法可以相當方便地查看變量中實際存儲著什么值。

現在我們將進入加法函數內部。
6. 單步->s

我們可以使用“s”進入加法函數內部。

(Pdb) s--Call--> /Users/someuser/debugger.py(4)add()-> def add(num1=0, num2=0):(Pdb) n> /Users/someuser/debugger.py(5)add()-> return int(num1) + int(num2)(Pdb)

這將把我們帶入加法函數的內部,現在我們可以在加法函數內部使用n、p和其他的操作指令。

此時單擊“r”將會把我們帶到前面進入函數的返回語句。

如果你想快速跳轉到一個函數的結尾處,那么這個指令將很有用。
7. 動態添加斷點- > b

前面,在程序運行之前,我們使用pdb.set_trace()設置了一個斷點。

不過,經常在調試會話已經開始之后,我們想要在程序中特定的地方添加斷點。

這里我們就可以使用選項“b”來實現這種目的。

我們重新開始執行程序。
 

['debugger.py', '1', '2']> /Users/someuser/debugger.py(15)main()-> addition = add(sys.argv[1], sys.argv[2])(Pdb)

此時我在第18行設置一個斷點。
 

-> addition = add(sys.argv[1], sys.argv[2])(Pdb) b 18Breakpoint 1 at /Users/someuser/debugger.py:18(Pdb) cWe are in add--3> /Users/someuser/debugger.py(18)main()-> print subtraction(Pdb) p subtraction-1(Pdb)

從上面我們可以看到,PDB跳到了第18行并等待下一個指令。

同時,PDB還為該斷點分配了一個號碼(在本例中是1)。為了以后的執行,我們可以通過開啟或禁用斷點號碼來啟用或停用對應的斷點。
8. 列表->l

有時在調試的時候,你可能會忘記此時你處在代碼的什么地方。在這種情況下,使用“l”將會打印出一個友好的總結,它能夠顯示出此刻你在代碼中的位置。
 

['debugger.py', '1', '2']> /Users/someuser/debugger.py(15)main()-> addition = add(sys.argv[1], sys.argv[2])(Pdb) l 10 11   def main(): 12     #Assuming our inputs are valid numbers 13     print sys.argv 14     pdb.set_trace() # <-- Break point added here 15 ->   addition = add(sys.argv[1], sys.argv[2]) 16     print addition 17     subtraction = sub(sys.argv[1], sys.argv[2]) 18     print subtraction

9. 動態分配變量

在調試會話期間,你可以分配變量來幫助你進行調試,知道這些對你來說也是有幫助的。例如:
 

['debugger.py', '1', '2']> /Users/someuser/debugger.py(15)main()-> addition = add(sys.argv[1], sys.argv[2])(Pdb) nWe are in add--> /Users/someuser/debugger.py(16)main()-> print addition(Pdb) p addition3 #<--- addition here is 3(Pdb) addition = 'this is now string' #<--- We changed the value of additon(Pdb) nthis is now string #<--- Now when we print it we actually gets it as a string. that we just set above.> /Users/someuser/debugger.py(17)main()-> subtraction = sub(sys.argv[1], sys.argv[2])

注意:
如果你想設置一些如n(即PDB指令)這樣的變量,你應該使用這種指令:
 

(Pdb) !n=5(Pdb) p n5

10. 結束->q

最后,在代碼的任何地方如果你想結束調試,可以使用“q”,那么正在執行的程序將會終止。
11. 擴展閱讀

本文只涉及到了PDB的表面用法,其實使用PDB你還可以做到更多(PDB 文檔)。

使用IPython的人可以在ipdb中找到一個更好的調試器,它提供了tab補充、語法高亮和其他一些很酷的特性。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 枣庄市| 河北省| 长葛市| 上思县| 呼和浩特市| 阿拉善盟| 鄂托克旗| 海伦市| 定安县| 湘阴县| 昭通市| 龙州县| 渭源县| 宁晋县| 开平市| 门头沟区| 贵德县| 海南省| 连山| 衢州市| 乌苏市| 宜章县| 香港| 隆昌县| 怀仁县| 海城市| 舒城县| 曲沃县| 广灵县| 淮安市| 平定县| 琼结县| 长沙县| 孟州市| 昭平县| 彝良县| 固安县| 阿克苏市| 乡宁县| 山西省| 固安县|