一行代碼干掉 debug 和 print

在寫算法的時(shí)候檀训,總是要每行每個(gè)變量一個(gè)個(gè)的 debug,有時(shí)候還要多寫幾個(gè) print留夜,一道算法題要花好長(zhǎng)時(shí)間才能理解包警。pysnooper 模塊可以把在運(yùn)行中變量值都給打印出來(lái)。\

模塊安裝

pip3 install pysnooper

簡(jiǎn)單例子

下面是道簡(jiǎn)單的力扣算法題作為一個(gè)簡(jiǎn)單的例子

import pysnooper

@pysnooper.snoop()
def longestCommonPrefix(strs):
    res = ''
    for i in zip(*strs):
        print(i)
        if len(set(i)) == 1:
            res += i[0]
        else
            break
    return res
 
if __name__ == 'main':
    longestCommonPrefix(["flower","flow","flight"])

結(jié)果:

3:38:25.863579 call         4 def longestCommonPrefix(strs):
23:38:25.864474 line         5     res = ''
New var:....... res = ''
23:38:25.864474 line         6     for i in zip(*strs):
New var:....... i = ('f', 'f', 'f')
23:38:25.865479 line         7         print(i)
('f', 'f', 'f')
23:38:25.866471 line         8         if len(set(i))==1:
23:38:25.866471 line         9             res+=i[0]
Modified var:.. res = 'f'
23:38:25.866471 line         6     for i in zip(*strs):
Modified var:.. i = ('l', 'l', 'l')
23:38:25.866471 line         7         print(i)
('l', 'l', 'l')
23:38:25.867468 line         8         if len(set(i))==1:
23:38:25.867468 line         9             res+=i[0]
Modified var:.. res = 'fl'
23:38:25.868476 line         6     for i in zip(*strs):
Modified var:.. i = ('o', 'o', 'i')
23:38:25.868476 line         7         print(i)
('o', 'o', 'i')
23:38:25.869463 line         8         if len(set(i))==1:
23:38:25.869463 line        11             break
23:38:25.869463 line        12     return res
23:38:25.869463 return      12     return res
Return value:.. 'fl'
Elapsed time: 00:00:00.008201

我們可以看到 pysnooper 把整個(gè)執(zhí)行程序都記錄了下來(lái),其中包括行號(hào)莉撇, 行內(nèi)容呢蛤,變量的結(jié)果等情況,我們很容易的就看懂了這個(gè)算法的真實(shí)情況棍郎。并且不需要再使用 debug 和 print 調(diào)試代碼顾稀。很是省時(shí)省力,只需要在方法上面加一行 @pysnooper.snoop()坝撑。

復(fù)雜使用

pysnooper 包含了多個(gè)參數(shù)静秆,一起來(lái)看看吧

output

output 默認(rèn)輸出到控制臺(tái),設(shè)置后輸出到文件巡李,在服務(wù)器中運(yùn)行的時(shí)候抚笔,特定的時(shí)間出現(xiàn)代碼問(wèn)題就很容易定位錯(cuò)誤了,不然容易抓瞎侨拦。小編在實(shí)際中已經(jīng)被這種問(wèn)題困擾了好幾次殊橙,每次都掉好多頭發(fā)。

@pysnooper.snoop('D:\pysnooper.log')
def longestCommonPrefix(strs):

示例結(jié)果:

watch 和 watch_explode

watch 用來(lái)設(shè)置跟蹤的非局部變量狱从,watch_explode 表示設(shè)置的變量都不監(jiān)控膨蛮,只監(jiān)控沒(méi)設(shè)置的變量,正好和 watch 相反季研。

index = 1
@pysnooper.snoop(watch=('index'))
def longestCommonPrefix(strs):

示例結(jié)果

沒(méi)有加 watch 參數(shù)

Starting var:.. strs = ['flower', 'flow', 'flight']
00:12:33.715367 call         5 def longestCommonPrefix(strs):
00:12:33.717324 line         7     res = ''
New var:....... res = ''

加了watch 參數(shù)敞葛,就會(huì)有一個(gè) Starting var:.. index

Starting var:.. strs = ['flower', 'flow', 'flight']
Starting var:.. index = 1
00:10:35.151036 call         5 def longestCommonPrefix(strs):
00:10:35.151288 line         7     res = ''
New var:....... res = ''

depth

depth 監(jiān)控函數(shù)的深度

@pysnooper.snoop(depth=2)
def longestCommonPrefix(strs):
    otherMethod()

示例結(jié)果

Starting var:.. strs = ['flower', 'flow', 'flight']
00:20:54.059803 call         5 def longestCommonPrefix(strs):
00:20:54.059803 line         6     otherMethod()
    00:20:54.060785 call        16 def otherMethod():        
    00:20:54.060785 line        17     x = 1
    New var:....... x = 1
    00:20:54.060785 line        18     x = x + 1
    Modified var:.. x = 2
    00:20:54.060785 return      18     x = x + 1
    Return value:.. None
00:20:54.061782 line         7     res = ''

監(jiān)控的結(jié)果顯示,當(dāng)監(jiān)控到調(diào)用的函數(shù)的時(shí)候与涡,記錄上會(huì)加上縮進(jìn)惹谐,并將它的局部變量和返回值打印處理。

prefix

prefix 輸出內(nèi)容的前綴

@pysnooper.snoop(prefix='-------------')
def longestCommonPrefix(strs):

示例結(jié)果

-------------Starting var:.. strs = ['flower', 'flow', 'flight']
-------------00:39:13.986741 call         5 def longestCommonPrefix(strs):
-------------00:39:13.987218 line         6     res = ''

relative_time

relative_time 代碼運(yùn)行的時(shí)間

@pysnooper.snoop(relative_time=True)
def longestCommonPrefix(strs):

示例結(jié)果

Starting var:.. strs = ['flower', 'flow', 'flight']
00:00:00.000000 call         5 def longestCommonPrefix(strs):
00:00:00.001998 line         6     res = ''
New var:....... res = ''
00:00:00.001998 line         7     for i in zip(*strs):

max_variable_length

max_variable_length 輸出的變量和異常的最大長(zhǎng)度驼卖,默認(rèn)是 100 個(gè)字符氨肌,超過(guò) 100 個(gè)字符就會(huì)被截?cái)啵梢栽O(shè)置為 max_variable_length=None 不截?cái)噍敵?/p>

@pysnooper.snoop(max_variable_length=5)
def longestCommonPrefix(strs):

示例結(jié)果

Starting var:.. strs = [...]
00:56:44.343639 call         5 def longestCommonPrefix(strs):
00:56:44.344696 line         6     res = ''
New var:....... res = ''
00:56:44.344696 line         7     for i in zip(*strs):      
New var:....... i = (...)

總結(jié)

本文介紹了怎么使用 pysnooper 工具酌畜,pysnooper 不僅可以少一些 debug 和 print怎囚,更能幫助理解算法題。

如果有收獲桥胞,還請(qǐng)點(diǎn)贊恳守、在看、轉(zhuǎn)發(fā)埠戳,感謝你的閱讀和支持井誉。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市整胃,隨后出現(xiàn)的幾起案子颗圣,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件在岂,死亡現(xiàn)場(chǎng)離奇詭異奔则,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)蔽午,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門易茬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人及老,你說(shuō)我怎么就攤上這事抽莱。” “怎么了骄恶?”我有些...
    開(kāi)封第一講書人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵食铐,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我僧鲁,道長(zhǎng)虐呻,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任寞秃,我火速辦了婚禮斟叼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘春寿。我一直安慰自己朗涩,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布堂淡。 她就那樣靜靜地躺著馋缅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪绢淀。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 52,441評(píng)論 1 310
  • 那天瘾腰,我揣著相機(jī)與錄音皆的,去河邊找鬼。 笑死蹋盆,一個(gè)胖子當(dāng)著我的面吹牛费薄,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播栖雾,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼楞抡,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了析藕?” 一聲冷哼從身側(cè)響起召廷,我...
    開(kāi)封第一講書人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后竞慢,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體先紫,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年筹煮,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了遮精。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡败潦,死狀恐怖本冲,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情劫扒,我是刑警寧澤眼俊,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站粟关,受9級(jí)特大地震影響疮胖,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜闷板,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一澎灸、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧遮晚,春花似錦性昭、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至萧求,卻和暖如春其兴,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背夸政。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工元旬, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人守问。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓匀归,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親耗帕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子穆端,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容