def now():
print('2016-06-03')
def log(text):
def decorator(func):
def wrapper(*args, **kw):
print('%s %s():' % (text, func.__name__))
return func(*args, **kw)
return wrapper
return decorator
@log('rain:')
def now():
print('2016-06-03')
now()
像上面那样,装饰后的函数的 __name__ 已经从 now 变成了 wrapper,为什么?
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
等价于
now变为log('rain:')(原来的now)然后解释下为啥__name__是wrapper
根据https://docs.python.org/2.7/library/inspect.html
所以
__name__是根据具体定义时候的来如另外一个例子
装饰之后的函数其实不是now函数了
而是log(“rain”)(now)
其实就是你定义的wrapper。
对于这个问题、functools里有个wraps可以把__name__之类的正确设置