Python裝飾器簡單用法實(shí)例小結(jié)
本文總結(jié)分析了Python裝飾器簡單用法。分享給大家供大家參考,具體如下:
裝飾器在python中扮演著很重要的作用,例如插入日志等,裝飾器可以為添加額外的功能同時(shí)又不影響業(yè)務(wù)函數(shù)的功能。
比如,運(yùn)行業(yè)務(wù)函數(shù)fun()同時(shí)打印運(yùn)行花費(fèi)的時(shí)間
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!
更多關(guān)于Python相關(guān)內(nèi)容可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對大家Python程序設(shè)計(jì)有所幫助。
相關(guān)文章
pandas刪除某行或某列數(shù)據(jù)的實(shí)現(xiàn)示例
本文主要介紹了pandas刪除某行或某列數(shù)據(jù)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
pycharm引入其他目錄的包報(bào)錯(cuò),import報(bào)錯(cuò)的解決
這篇文章主要介紹了pycharm引入其他目錄的包報(bào)錯(cuò),import報(bào)錯(cuò)的解決,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08
Python求解排列中的逆序數(shù)個(gè)數(shù)實(shí)例
這篇文章主要介紹了Python求解排列中的逆序數(shù)個(gè)數(shù)實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-05-05

