這期內(nèi)容當中小編將會給大家?guī)碛嘘P如何在Python中應用裝飾器,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
我們提供的服務有:成都網(wǎng)站制作、做網(wǎng)站、微信公眾號開發(fā)、網(wǎng)站優(yōu)化、網(wǎng)站認證、瓊中黎族ssl等。為上千家企事業(yè)單位解決了網(wǎng)站和推廣的問題。提供周到的售前咨詢和貼心的售后服務,是有科學管理、有技術的瓊中黎族網(wǎng)站制作公司1. 運行業(yè)務函數(shù)fun()
同時打印運行花費的時間
import time def dec(fun): start = time.time() fun() end = time.time() a = end - start print a def myfun(): print 'run myfunction' dec(myfun)
運行結果
(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.00108599662781
但是每次運行myfun都要調(diào)用dec,下面作下變動解決這個問題
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()
運行結果:
(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.00122618675232
這個裝飾器dec就實現(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()
結果
(virt2) root@ubuntu:/home/z# python z.py
run myfunction
0.000470876693726
使用了@后,就不用給myfun重新賦值了
@dec
就相當于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)
輸出:
python有哪些常用庫[INFO]: enter function say()
say 123!
python常用的庫:1.requesuts;2.scrapy;3.pillow;4.twisted;5.numpy;6.matplotlib;7.pygama;8.ipyhton等。
上述就是小編為大家分享的如何在Python中應用裝飾器了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
文章名稱:如何在Python中應用裝飾器-創(chuàng)新互聯(lián)
新聞來源:http://muchs.cn/article18/dieogp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設、網(wǎng)站制作、微信小程序、面包屑導航、移動網(wǎng)站建設、標簽優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容