更多課程 選擇中心

Python培訓
美國上市教育機構

400-111-8989

Python培訓

這個Python調試工具,你需要嗎?

  • 發布:Python培訓
  • 來源:開源最前線
  • 時間:2019-04-28 17:07

我們在進行Python編碼的過程中,經常會對代碼進行調試,看看代碼是不是按照預期執行,哪些沒有按照預期執行等,我們經常使用會使用包含斷點和觀察模式等功能成熟的調試器,或者直接使用 print 語句打印出來,但是今天小編想和大家分享一個“貧民版”調試工具——PySnooper,你有興趣嗎?

PySnooper允許你執行以上相同的操作,只需為要調試的函數添加一個裝飾器即可,而不需要構建正確的 print 打印。你還將得到函數的詳細日志,包括運行了哪些代碼行、何時運行以及何時更改了局部變量。

PySnooper 使用起來十分簡單,開發者可以在任何龐大的代碼庫中使用它,而無需進行任何設置。你只需添加裝飾器,并為日志輸出地址指定路徑,方法是將其路徑指定為第一個參數。

目前,PySnooper在GitHub上已經獲得 7047 個Star,371 個Fork(GitHub地址:https://github.com/cool-RR/PySnooper)

示例

以下編寫了一個函數,通過返回一個二進制列表。我們只需要通過添加@pysnooper.snoop()裝飾器就可以了:

import pysnooper

@pysnooper.snoop()
def number_to_bits(number):
    if number:
        bits = []
        while number:
            number, remainder = divmod(number, 2)
            bits.insert(0, remainder)
        return bits
    else:
        return [0]

umber_to_bits(6)

輸出如下:

Starting var:.. number = 6
15:29:11.327032 call         4 def number_to_bits(number):
15:29:11.327032 line         5     if number:
15:29:11.327032 line         6         bits = []
New var:....... bits = []
15:29:11.327032 line         7         while number:
15:29:11.327032 line         8             number, remainder = divmod(number, 2)
New var:....... remainder = 0
Modified var:.. number = 3
15:29:11.327032 line         9             bits.insert(0, remainder)
Modified var:.. bits = [0]
15:29:11.327032 line         7         while number:
15:29:11.327032 line         8             number, remainder = divmod(number, 2)
Modified var:.. number = 1
Modified var:.. remainder = 1
15:29:11.327032 line         9             bits.insert(0, remainder)
Modified var:.. bits = [1, 0]
15:29:11.327032 line         7         while number:
15:29:11.327032 line         8             number, remainder = divmod(number, 2)
Modified var:.. number = 0
15:29:11.327032 line         9             bits.insert(0, remainder)
Modified var:.. bits = [1, 1, 0]
15:29:11.327032 line         7         while number:
15:29:11.327032 line        10         return bits
15:29:11.327032 return      10         return bits
Return value:.. [1, 1, 0]

特性

stderr,則可以將選擇輸出到指定文件:

@pysnooper.snoop('/my/log/file.log')

查看一些非局部變量的變量值:

@pysnooper.snoop(variables=('foo.bar', 'self.whatever'))

顯示函數調用的函數的snoop行:

@pysnooper.snoop(depth=2)

感謝您的閱讀,以上就是對Python調試器PySnooper的介紹,你清楚了嗎?可以在你的工作中應用一下哦,更多Python相關的內容盡在達內Python培訓機構官網,敬請關注!

免責聲明:內容和圖片源自網絡,版權歸原作者所有,如有侵犯您的原創版權請告知,我們將盡快刪除相關內容。

預約申請免費試聽課

填寫下面表單即可預約申請免費試聽!怕錢不夠?可就業掙錢后再付學費! 怕學不會?助教全程陪讀,隨時解惑!擔心就業?一地學習,可全國推薦就業!

上一篇:如果你要在2019年學點什么,我推薦你學Python!
下一篇:Star 數達到 26000+,這是什么Python算法?

交錢了,學了3天Python編程,我想放棄了......

學習Python編程這么久了,你是青銅還是王者?

Star 數達到 26000+,這是什么Python算法?

這個Python調試工具,你需要嗎?

選擇城市和中心
黑龍江省

吉林省

河北省

湖南省

貴州省

云南省

廣西省

海南省

4438全国大成网人网站