中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

詳解DeBug Python神級工具PySnooper

發布時間:2020-09-20 10:21:00 來源:腳本之家 閱讀:180 作者:今夜睡火星 欄目:開發技術

PySnooper 在 GitHub 上自嘲是一個“乞丐版”調試工具(poor man's debugger)。

一般情況下,在編寫 Python 代碼時,如果想弄清楚為什么 Python 代碼沒有按照預期執行、哪些代碼在運行哪些沒在運行、局部變量又是什么,我們會使用包含斷點和觀察模式等功能的調試器,或者直接使用 print 語句打印出來。

但上面的方法都比較麻煩,例如使用調試器需要進行繁瑣的設置,使用 print 打印也要很仔細。與它們相比,使用 PySnooper 只需為要調試的函數添加一個裝飾器即可,這樣就能獲得運行函數詳細的 log,包括執行的代碼行和執行時間,以及局部變量發生變化的確切時間。

之所以稱為“乞丐版”,相信是因為 PySnooper 使用起來十分簡單,開發者可以在任何龐大的代碼庫中使用它,而無需進行任何設置。只需添加裝飾器,并為日志輸出地址指定路徑。

GitHub項目地址

安裝

pip3 install pysnooper
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]

number_to_bits(6)

返回日志如下

Starting var:.. number = 6
21:14:32.099769 call         3 @pysnooper.snoop()
21:14:32.099769 line         5     if number:
21:14:32.099769 line         6         bits = []
New var:....... bits = []
21:14:32.099769 line         7         while number:
21:14:32.099769 line         8             number, remainder = divmod(number, 2)
New var:....... remainder = 0
Modified var:.. number = 3
21:14:32.099769 line         9             bits.insert(0, remainder)
Modified var:.. bits = [0]
21:14:32.099769 line         7         while number:
21:14:32.099769 line         8             number, remainder = divmod(number, 2)
Modified var:.. number = 1
Modified var:.. remainder = 1
21:14:32.099769 line         9             bits.insert(0, remainder)
Modified var:.. bits = [1, 0]
21:14:32.099769 line         7         while number:
21:14:32.099769 line         8             number, remainder = divmod(number, 2)
Modified var:.. number = 0
21:14:32.099769 line         9             bits.insert(0, remainder)
Modified var:.. bits = [1, 1, 0]
21:14:32.099769 line         7         while number:
21:14:32.099769 line        10         return bits
21:14:32.099769 return      10         return bits

PySnooper特征

如果標準錯誤輸出難以獲得,或者太長了,那么可以將輸出定位到本地文件:

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

查看一些非本地變量的值:

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

展示我們函數中調用函數的 snoop 行:

@pysnooper.snoop(depth=2)

將所有 snoop 行以某個前綴開始,更容易定位和找到:

@pysnooper.snoop(prefix='ZZZ ')

更可以用來獲取TensorFlow 的各種張量信息,十分強大。媽媽再也不用擔心我找不到bug啦!
(2019.5.7更新:有時會不起作用,不知是自己姿勢不對還是其他原因。)

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

泰顺县| 蚌埠市| 隆尧县| 平邑县| 四川省| 聂拉木县| 中卫市| 广南县| 海阳市| 客服| 上杭县| 当雄县| 浦城县| 苍溪县| 苏尼特左旗| 佛冈县| 兴隆县| 颍上县| 泽库县| 西青区| 化德县| 鹤峰县| 兴国县| 广州市| 罗定市| 聊城市| 江西省| 新昌县| 内丘县| 革吉县| 重庆市| 花垣县| 济宁市| 富裕县| 靖远县| 岳池县| 平阴县| 堆龙德庆县| 兴业县| 忻州市| 贵港市|