掌握Python系統(tǒng)管理-調(diào)試和分析腳本3- 2019新神器pysnooper:偷窺比print更方便

PySnooper - 不要再使用print進(jìn)行調(diào)試

斷點(diǎn)等調(diào)試方法雖然強(qiáng)大,但是設(shè)置比較麻煩。為此print成了很多人的最愛。

PySnooper讓你做print的事情,但不需要麻煩地添加很多語句,你只需要添加裝飾器就可以得到運(yùn)行日志,包括線運(yùn)行,及對(duì)應(yīng)變量的值。

參考資料

實(shí)例

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)

執(zhí)行:

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

特征

如果不方便訪問stderr,則可以重定向到文件:

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

查看非局部變量的值:

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

顯示函數(shù)調(diào)用的snoop行:

@pysnooper.snoop(depth=2)

窺探指定前綴的行:

@pysnooper.snoop(prefix ='ZZZ')

安裝

pip install pysnooper
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容