您好,登錄后才能下訂單哦!
這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)如何在Python中應(yīng)用裝飾器,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
1. 運(yùn)行業(yè)務(wù)函數(shù)fun()
同時(shí)打印運(yùn)行花費(fèi)的時(shí)間
import time def dec(fun): start = time.time() fun() end = time.time() a = end - start print a def myfun(): print 'run myfunction' dec(myfun)
運(yùn)行結(jié)果
(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.00108599662781
但是每次運(yùn)行myfun都要調(diào)用dec,下面作下變動解決這個(gè)問題
2.
import time def dec(fun): def wrap(): start = time.time() fun() end = time.time() a = end - start print a return wrap def myfun(): print 'run myfunction' myfun=dec(myfun) myfun()
運(yùn)行結(jié)果:
(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.00122618675232
這個(gè)裝飾器dec就實(shí)現(xiàn)了,并且不影響函數(shù)myfun功能
3. 裝飾器@符
import time def dec(fun): def wrap(): start = time.time() fun() end = time.time() a = end - start print a return wrap @dec def myfun(): print 'run myfunction' myfun()
結(jié)果
(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.000470876693726
使用了@后,就不用給myfun重新賦值了
@dec
就相當(dāng)于myfun=dec(myfun)
例子:
def level(leveel): def debug(func): def wrapper(*args, **kwargs): print("[DEBUG]: enter {}()".format(func.__name__),leveel) return func(*args, **kwargs) return wrapper return debug @level(leveel='debuging') def say(something): print ("hello {}!".format(something)) say(123)
輸出:
('[DEBUG]: enter say()', 'debuging')
hello 123!
''' class logging(object): def __init__(self, func): self.func = func def __call__(self, *args, **kwargs): print ("[DEBUG]: enter function {func}()".format( func=self.func.__name__)) return self.func(*args, **kwargs) @logging def say(something): print ("say {}!".format(something)) ''' class logging(object): def __init__(self, level='INFO'): self.level = level def __call__(self, func): # 接受函數(shù) def wrapper(*args, **kwargs): print ("[{level}]: enter function {func}()".format( level=self.level, func=func.__name__)) func(*args, **kwargs) return wrapper #返回函數(shù) @logging(level='INFO') def say(something): print ("say {}!".format(something)) say(123)
輸出:
[INFO]: enter function say()
say 123!
python常用的庫:1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。
上述就是小編為大家分享的如何在Python中應(yīng)用裝飾器了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。