import time
#裝飾器函式
def show_time(f):
def inner():
start = time.time()
f()end = time.time()
print('spend %s'%(end-start))
return inner
#通過@show_time呼叫
@show_time
def bar():
print('bar...........')
def foo():
print('foo...')
foo()
# bar=show_time(bar)
bar()
裝飾器類似與上面,先編寫函式的功能模組
通過@showtime來完成函式的功能追加
@showtime作用其實就是呼叫上面的閉包函式show_time
如果裝飾器中需要新增部分其他擴充套件的功能,可以給裝飾器帶上引數,如下:
import time
def logger(flag=''):
def show_time(f):
def inner(*x,**y):
start = time.time()
f(*x,**y)
end = time.time()
print('spend %s'%(end-start))
if flag == 'true':
print('日誌記錄')
return inner
return show_time
@logger('true')
def bar():
print('bar...........')
@logger('true')
def add(*x,**y):
total=0
for temp in x:
total+=temp
print(total)
@logger()
def foo():
print('foo...')
# foo()
# bar=show_time(bar)
#bar()
add(1,5,3,6,2,4)
foo()
python裝飾器 函式裝飾器,類裝飾器
只要實現此 模式,這個obj就叫乙個裝飾器 參考 函式裝飾器 例子 def decorator func def inner args,kwargs print before.res func args,kwargs print after.return res return inner decor...
python 裝飾器 函式裝飾器 類裝飾器
python函式裝飾器和類裝飾器筆記.usr bin env python coding utf 8 author ivan file decorators.py version from functools import wraps 裝飾器 目的是為了給函式新增附加功能 1.不帶引數裝飾器 此方式...
python裝飾器 裝飾器工廠函式
使用裝飾器實現如下所示的列印 小白聯盟def printequel func1 def inner1 print 15 func1 return inner1 def printstar func2 def inner2 print 15 func2 return inner2 printequel...