一个普通的装饰器应该这样写:
def log(func):
def wrapper(*args, **kw):
print('call %s():' % func.__name__)
return func(*args, **kw)
return wrapper
但是我困惑了好久,为什么中间会有个wrapper函数?
def log(func):
print('call %s():' % func.__name__)
return func(*args, **kw)
不也是可以实现执行函数之前输出语句么?
但是仔细看装饰器的定义,装饰器是要在我们调用这个函数的时候才会输出装饰器里面的内容,装饰器相当于实现了语句
@log
def now():
print('2015-3-25')
now = log(now)
如果按照第二种方法写,那么在没调用now的情况下我们也会得出一条装饰器的输出语句,因为这时候log函数执行了,所以需要第一种写法来返回一个函数