functools.wraps: update_wrapper的封裝

This is a convenience function for invoking partial(update_wrapper,wrapped=wrapped,assigned=assigned,updated=updated) as a function decorator when defining a wrapper function.

import functools

def log_cost_time(func):

? ? @functools.wraps(func)

? ? def wrapped(*args, **kwargs):

? ? ? ? import time

? ? ? ? begin = time.time()

? ? ? ? try:

? ? ? ? ? ? return func(*args, **kwargs)

? ? ? ? finally:

? ? ? ? ? ? print 'func %s cost %s' % (func.__name__, time.time() - begin)

? ? return wrapped

再查看complex_func.__name__ 輸出就是 “complex_func”

裝飾器也是可以帶參數(shù)的胸完。

def log_cost_time(stream):

? ? def inner_dec(func):

? ? ? ? def wrapped(*args, **kwargs):

? ? ? ? ? ? import time

? ? ? ? ? ? begin = time.time()

? ? ? ? ? ? try:

? ? ? ? ? ? ? ? return func(*args, **kwargs)

? ? ? ? ? ? finally:

? ? ? ? ? ? ? ? stream.write('func %s cost %s ' % (func.__name__, time.time() - begin))

? ? ? ? return wrapped

? ? return inner_dec

import sys

@log_cost_time(sys.stdout)

def complex_func(num):

? ? ret = 0

? ? for i in xrange(num):

? ? ? ? ret += i * i

? ? return ret

if __name__ == '__main__':

? ? print complex_func(100000)

code snippet 1

log_cost_time函數(shù)也接受一個(gè)參數(shù)呆贿,該參數(shù)用來指定信息的輸出流,對(duì)于帶參數(shù)的decorator

@dec(dec_args)

def func(*args, **kwargs):pass

等價(jià)于 func = dec(dec_args)(*args, **kwargs)蝠筑。

裝飾器對(duì)類的修飾也是很簡(jiǎn)單的皆警,只不過平時(shí)用得不是很多。舉個(gè)例子等浊,我們需要給修改類的__str__方法屯曹,代碼很簡(jiǎn)單瓢喉。

def Haha(clz):

? ? clz.__str__ = lambda s: "Haha"

? ? return clz

class Widget(object):

? ? ''' class Widget '''

if __name__ == '__main__':

? ? w = Widget()

? ? print w

那什么場(chǎng)景下有必要使用decorator呢宁赤,設(shè)計(jì)模式中有一個(gè)模式也叫裝飾器。我們先簡(jiǎn)單回顧一下設(shè)計(jì)模式中的裝飾器模式栓票,簡(jiǎn)單的一句話概述

動(dòng)態(tài)地為某個(gè)對(duì)象增加額外的責(zé)任

  由于裝飾器模式僅從外部改變組件决左,因此組件無需對(duì)它的裝飾有任何了解;


回到Python中來走贪,用decorator語法實(shí)現(xiàn)裝飾器模式是很自然的哆窿,比如文中的示例代碼,在不改變被裝飾對(duì)象的同時(shí)增加了記錄函數(shù)執(zhí)行時(shí)間的額外功能厉斟。當(dāng)然挚躯,由于Python語言的靈活性,decorator是可以修改被裝飾的對(duì)象的(比如裝飾類的例子)擦秽。decorator在python中用途非常廣泛码荔,下面列舉幾個(gè)方面:

(1)修改被裝飾對(duì)象的屬性或者行為

(2)處理被函數(shù)對(duì)象執(zhí)行的上下文,比如設(shè)置環(huán)境變量感挥,加log之類

(3)處理重復(fù)的邏輯缩搅,比如有N個(gè)函數(shù)都可能跑出異常,但是我們不關(guān)心這些異常触幼,只要不向調(diào)用者傳遞異常就行了硼瓣,這個(gè)時(shí)候可以寫一個(gè)catchall的decorator,作用于所用可能跑出異常的函數(shù)

def catchall(func):

? ? @functools.wraps(func)

? ? def wrapped(*args, **kwargs):

? ? ? ? try:

? ? ? ? ? ? return func(*args, **kwargs)

? ? ? ? except:

? ? ? ? ? ? pass

? ? return wrapped

(4)框架代碼置谦,如flask堂鲤, bottle等等,讓使用者很方便就能使用框架媒峡,本質(zhì)上也避免了重復(fù)代碼瘟栖。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市谅阿,隨后出現(xiàn)的幾起案子半哟,更是在濱河造成了極大的恐慌酬滤,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件寓涨,死亡現(xiàn)場(chǎng)離奇詭異盯串,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)戒良,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門体捏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蔬墩,你說我怎么就攤上這事『耐兀” “怎么了拇颅?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)乔询。 經(jīng)常有香客問我樟插,道長(zhǎng),這世上最難降的妖魔是什么竿刁? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任黄锤,我火速辦了婚禮,結(jié)果婚禮上食拜,老公的妹妹穿的比我還像新娘鸵熟。我一直安慰自己,他們只是感情好负甸,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布流强。 她就那樣靜靜地躺著,像睡著了一般呻待。 火紅的嫁衣襯著肌膚如雪打月。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天蚕捉,我揣著相機(jī)與錄音奏篙,去河邊找鬼。 笑死迫淹,一個(gè)胖子當(dāng)著我的面吹牛秘通,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播敛熬,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼充易,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了荸型?” 一聲冷哼從身側(cè)響起盹靴,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤炸茧,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后稿静,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體梭冠,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年改备,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了控漠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡悬钳,死狀恐怖盐捷,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情默勾,我是刑警寧澤碉渡,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站母剥,受9級(jí)特大地震影響滞诺,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜环疼,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一习霹、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧炫隶,春花似錦淋叶、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至望门,卻和暖如春形娇,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背筹误。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工桐早, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人厨剪。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓哄酝,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親祷膳。 傳聞我的和親對(duì)象是個(gè)殘疾皇子陶衅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

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

  • 裝飾是為函數(shù)和類指定管理代碼的一種方式.裝飾器本身的形式是處理其他的可調(diào)用對(duì)象的可調(diào)用的對(duì)象。 函數(shù)裝飾器在函數(shù)定...
    低吟淺唱1990閱讀 224評(píng)論 0 0
  • Python裝飾器的高級(jí)用法(翻譯) 原文地址https://www.codementor.io/python/t...
    城南道閱讀 4,809評(píng)論 1 22
  • 這兩天學(xué)習(xí)的時(shí)候?qū)ython中的閉包產(chǎn)生了興趣直晨,網(wǎng)上這篇文章寫得很好搀军,寫在這里大家看看膨俐。 1. 閉包的概念 首...
    Alistair閱讀 256評(píng)論 0 0
  • 回到本心,回到過去罩句,過去在美化的濾鏡中呈現(xiàn)出鏡花水月的模糊輪廓焚刺,你不甘心,伸手狠狠地抓去门烂,自然無所得——所謂的“過...
    王大可Rukia閱讀 1,669評(píng)論 7 18
  • 他和孩子在那 我在這 這就是最好的時(shí)光
    仉婧閱讀 192評(píng)論 0 0