亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

詳解DeBug Python神級工具PySnooper

系統(tǒng) 1776 0

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

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

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

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

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'))
          

展示我們函數(shù)中調用函數(shù)的 snoop 行:

            
@pysnooper.snoop(depth=2)
          

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

            
@pysnooper.snoop(prefix='ZZZ ')
          

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

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


更多文章、技術交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 337p色噜噜| 免费成人高清视频 | 奇米影视色 | 人人干人人干 | 国产成人三级 | 午夜私人| www.国产精品 | 久久伦理影院 | 国产成人啪午夜精品网站 | 国产国语一级a毛片高清视频 | 久久999视频 | 亚洲成人一区二区 | 日韩高清一区二区三区不卡 | 欧美视频在线一区二区三区 | 国产91在线免费 | 国产色视频一区二区三区 | 亚洲国产成人超福利久久精品 | 热久久国产欧美一区二区精品 | 在线日韩不卡 | 日本wwwsss | 日韩一区二区国色天香 | 日韩精品久久久毛片一区二区 | 亚洲欧洲日产国码久在线观看 | 久久黄色免费 | 国内国产精品天干天干 | 国产欧美亚洲精品一区 | 欧美性一区二区三区五区 | 手机看片高清国产日韩片 | 国内精品视频在线观看 | 福利院肉动漫视频在线观看 | 亚洲国产成人精品女人久久久 | 波多野结衣乳巨码无在线观看 | 国产91精品久久久久999 | 久久高清一区二区三区 | 午夜情趣视频 | 欧美成人午夜精品一区二区 | 久久99国产这里有精品视 | 热99re久久精品天堂vr | 日本无翼乌全彩无遮挡动漫 | 色综合天天操 | 国产一级一片免费播放 |