@语法的规则是,遇到@修饰的函数,会先执行下一行的函数,将其作为@行语句函数的参数,最后返回给下一行函数。@time1 等效于 time1(xxx),@logger等于logger(add) 所以会先将xxx函数作为参数传入tim1函数中,执行time1函数print参数的函数名称的任务后,再执行xxx函数本身的内容。
import time
def time1(func):
def inner(*args):
print(time.ctime())
func(*args)
return inner
@time1
def xxx(name):
print(name, 'NB')
xxx('sam')
def logger(func):
def wrapper(*args, **kw):
print ('do {}'.format(func.__name__))
func(*args, **kw)
print ('finish')
return wrapper
@logger
def add(x,y):
print ('{} + {} = {}'.format(x,y,x+y))
add(3,5)
比如要给函数add增加新功能,不在add函数里写东东,就在外面再定义一个新函数 装饰器即在不修改被装饰对象源代码与调用方式的前提下,为被装饰器对象添加新功能 @deco1 @deco2 @deco3 def foo(): pass
foo=deco1(deco2(deco3(foo)))
|