python - 函数签名问题
ringa_lee
ringa_lee 2017-04-17 17:52:40
0
3
975
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,为什么?

ringa_lee
ringa_lee

ringa_lee

全部回覆(3)
黄舟

等價於 now 变为 log('rain:')(原来的now)

接著解釋下為啥__name__是wrapper

根據https://docs.python.org/2.7/library/inspect.html

__name__: name with which this function was defined

所以__name__是根據具體定義時候的來

如另外一個例子

>>> def func():
...     pass
... 
>>> new_func = func
>>> print func.__name__
func
>>> print new_func.__name__
func
洪涛

裝飾之後的函數其實不是now函數了

而是log(「rain」)(now)
其實就是你定義的wrapper。

對於這個問題、functools裡有個wraps可以把__name__之類的正確設定

Peter_Zhu

雷雷

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板