从参考资料给的例子分析:
def log(func):
def wrapper(*args, **kw):
print('call %s():' % func.__name__)
return func(*args, **kw)
return wrapper
@log # 此时可以这么理解:调用了log方法,并将 now 作为实参传入,返回的函数赋值给 now 变量
def now():
print('2015-3-25')
now()
# call now():
# 2015-3-25
def log2():
def decorator(func):
def wrapper(*args, **kw):
print('call %s():' % func.__name__)
return func(*args, **kw)
return wrapper
return decorator
@log2() # 这种情况是先调用 log2(),其返回的 函数作为实际装饰器。所以decorator也会被调用
def now2():
print('2015-3-25')
https://www.liaoxuefeng.com/wiki/1016959663602400/1017451662295584