日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

詳解DeBug Python神級(jí)工具PySnooper

系統(tǒng) 1752 0

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

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

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

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

GitHub項(xiàng)目地址

安裝

            
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特征

如果標(biāo)準(zhǔn)錯(cuò)誤輸出難以獲得,或者太長(zhǎng)了,那么可以將輸出定位到本地文件:

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

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

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

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

            
@pysnooper.snoop(depth=2)
          

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

            
@pysnooper.snoop(prefix='ZZZ ')
          

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長(zhǎng)會(huì)非常 感謝您的哦?。。?/p>

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 南宁市| 灵宝市| 兰州市| 曲水县| 垣曲县| 山阳县| 永寿县| 鹿邑县| 诸暨市| 崇州市| 光山县| 中江县| 酉阳| 象山县| 黄梅县| 乌恰县| 徐水县| 湖州市| 洪泽县| 孟津县| 句容市| 富锦市| 阜南县| 长治市| 鲜城| 专栏| 沽源县| 若尔盖县| 江门市| 芜湖县| 拉萨市| 泗水县| 佛学| 象州县| 天镇县| 奉新县| 抚宁县| 柳江县| 喀什市| 漠河县| 宿松县|