溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Python的第三方調(diào)試庫pysnooper??如何使用

發(fā)布時(shí)間:2023-02-24 16:12:15 來源:億速云 閱讀:93 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“Python的第三方調(diào)試庫pysnooper如何使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Python的第三方調(diào)試庫pysnooper如何使用”吧!

一、背景

我們?cè)谶M(jìn)行代碼調(diào)試時(shí),通常使用兩種方式。

  • print 輸出調(diào)試的內(nèi)容或者標(biāo)識(shí)

  • 通過斷點(diǎn)調(diào)試debug
    但是我想知道代碼的中間的每一行程序運(yùn)行后的結(jié)果,方便的知道每一行程序運(yùn)行后的結(jié)果,而不需要再手動(dòng)增加 print 展示過程數(shù)據(jù)、調(diào)試程序
    Python 的第三方調(diào)試庫**pysnooper**。通過裝飾器輕松搞定

二、示例  pysnooper`

pip install pysnooper

  • 示例一跟蹤整個(gè)函數(shù)

import pysnooper

@pysnooper.snoop()
def number_to_bits(number):
for i in range(4):
print(i)

number_to_bits(2)
import pysnooper
import random

def foo():
lst = []
for i in range(10):
lst.append(random.randrange(1, 1000))

with pysnooper.snoop():
lower = min(lst)
upper = max(lst)
mid = (lower + upper) / 2
print(lower, mid, upper)
foo()

  • 示例二 跟蹤相關(guān)部分

三、方法

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

@pysnooper.snoop('/my/log/file.log')
  • 查看一些非本地變量的值:

@pysnooper.snoop(variables=('foo.bar', 'self.whatever'))
  • 展示函數(shù)調(diào)用的函數(shù)的監(jiān)聽行

@pysnooper.snoop(depth=2)
  • 將所有 監(jiān)聽行以某個(gè)前綴開始,更容易定位和找到:

@pysnooper.snoop(prefix='ZZZ ')
  •  高級(jí)更多

到此,相信大家對(duì)“Python的第三方調(diào)試庫pysnooper如何使用”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI