python裝飾器

python 裝飾器真是很好的設(shè)計(jì)模式摄悯。不會污染你的功能代碼赞季。

工作中裝飾器用到的地方主要有:記錄log,計(jì)算函數(shù)運(yùn)行所需的時(shí)間以及函數(shù)失敗后的重試奢驯。

下面是失敗后重試的裝飾器代碼申钩,僅供參考。

其中@functools.wraps(func)這句代碼會把被裝飾的函數(shù)的name屬性復(fù)制到wrapper()函數(shù)中叨橱。

當(dāng)然等價(jià)的代碼:wrapper.name = func.name 也是可以的典蜕。但是還是優(yōu)先使用functools。

import time
import functools

# 裝飾器1罗洗,每次重試操作之間的延時(shí)時(shí)間隨著循環(huán)逐漸延長

def deco(num=5):
    ''' 裝飾器: 參數(shù)num是重試的次數(shù)愉舔,默認(rèn)是5次'''
    def _deco(func):
        @functools.wraps(func)
        def wrapper(*args, **kwargs):
            for i in xrange(num):
                ret = func(*args, **kwargs)
                if ret:
                    break
                else:
                    time.sleep(i)
                    print "Retry %s" % i
            return ret
        return wrapper
    return _deco


@deco(num=2)
def myfunc(arg):
    ''' 功能函數(shù),需要返回執(zhí)行成功或失敗的標(biāo)志 '''
    print arg
    return True



這個(gè)裝飾器伙菜,可以自定義每次重試操作之間的延時(shí)時(shí)間轩缤,每次操作之間的時(shí)間都一樣

def retry_deco(num=5, sleep_time=1):
    """
    :param num:重試的次數(shù),數(shù)值型,默認(rèn)5次贩绕,使用時(shí)可修改
    :param sleep_time: 每次重試之間延時(shí)的時(shí)間,數(shù)值型, 單位為s火的,默認(rèn)1s掠归,使用時(shí)可修改
    :return:可調(diào)用的函數(shù)對象
    :description:重試裝飾器
    """
    if sleep_time < 0:
        sleep_time = 0

    def _deco(func):
        @functools.wraps(func)
        def wrapper(*args, **kwargs):
            ret = None
            for i in xrange(num):
                ret = func(*args, **kwargs)
                if ret:
                    break
                time.sleep(sleep_time)
                print "Retry %s羽杰, sleep time: %s" % (i, sleep_time)
            return ret
        return wrapper
    return _deco


@retry_deco(num=10, sleep_time=5)
def test(arg):
    return True

if __name__ == "__main__":
    print myfunc("xxxxxx")
    test(10)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末岳遥,一起剝皮案震驚了整個(gè)濱河市慷蠕,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌劫狠,老刑警劉巖栅干,帶你破解...
    沈念sama閱讀 212,884評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件新锈,死亡現(xiàn)場離奇詭異,居然都是意外死亡治力,警方通過查閱死者的電腦和手機(jī)蒙秒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宵统,“玉大人晕讲,你說我怎么就攤上這事÷沓海” “怎么了瓢省?”我有些...
    開封第一講書人閱讀 158,369評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長箭券。 經(jīng)常有香客問我净捅,道長疑枯,這世上最難降的妖魔是什么辩块? 我笑而不...
    開封第一講書人閱讀 56,799評論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮荆永,結(jié)果婚禮上废亭,老公的妹妹穿的比我還像新娘。我一直安慰自己具钥,他們只是感情好豆村,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著骂删,像睡著了一般掌动。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上宁玫,一...
    開封第一講書人閱讀 50,096評論 1 291
  • 那天粗恢,我揣著相機(jī)與錄音,去河邊找鬼欧瘪。 笑死眷射,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的佛掖。 我是一名探鬼主播妖碉,決...
    沈念sama閱讀 39,159評論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼芥被!你這毒婦竟也來了欧宜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,917評論 0 268
  • 序言:老撾萬榮一對情侶失蹤拴魄,失蹤者是張志新(化名)和其女友劉穎冗茸,沒想到半個(gè)月后猛拴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,360評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蚀狰,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評論 2 327
  • 正文 我和宋清朗相戀三年愉昆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片麻蹋。...
    茶點(diǎn)故事閱讀 38,814評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡跛溉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出扮授,到底是詐尸還是另有隱情芳室,我是刑警寧澤,帶...
    沈念sama閱讀 34,509評論 4 334
  • 正文 年R本政府宣布刹勃,位于F島的核電站堪侯,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏荔仁。R本人自食惡果不足惜伍宦,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望乏梁。 院中可真熱鬧次洼,春花似錦、人聲如沸遇骑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽落萎。三九已至亥啦,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間练链,已是汗流浹背翔脱。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留兑宇,地道東北人碍侦。 一個(gè)月前我還...
    沈念sama閱讀 46,641評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像隶糕,于是被迫代替她去往敵國和親瓷产。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評論 2 351