第三章:算法-functools:管理函数的工具-修饰符-获取修饰符的函数属性

使用functools.wraps保留装饰器元数据
本文详细介绍了如何使用Python的functools模块中的wraps函数来保持被装饰函数的元数据,如函数名和文档字符串。通过示例展示了装饰器语法和显式包裹函数的方法,并比较了它们在修饰后的函数属性上的区别。

3.1.1.5 获取修饰符的函数属性
更新所包装callable的属性对修饰符尤其有用,因为转换后的函数最后会得到原"裸"函数的属性。

import functools

def show_details(name,f):
    "Show details of a callable object."
    print('{}:'.format(name))
    print('  object:',f)
    print('  __name__:',end=' ')

    try:
        print(f.__name__)
    except AttributeError:
        print('(no __name__)')
    print('  __doc__',repr(f.__doc__))
    print()

def simple_decorator(f):
    @functools.wraps(f)
    def decorated(a='decorated defaults',b=1):
        print('  decorated:',(a,b))
        print('  ',end=' ')
        return f(a,b=b)
    return decorated

def myfunc(a,b=2):
    "myfunc() is not complicated"
    print('  myfunc:',(a,b))
    return

# The raw function
show_details('myfunc',myfunc)
myfunc('unwrapped,default b')
myfunc('unwrapped,passing b',3)
print()

# Wrap explicitly.
wrapped_myfunc = simple_decorator(myfunc)
show_details('wrapped_myfunc',wrapped_myfunc)
wrapped_myfunc()
wrapped_myfunc('args to wrapped',4)
print()

# Wrap with decorator syntax.
@simple_decorator
def decorated_myfunc(a,b):
    myfunc(a,b)
    return

show_details('decorated_myfunc',decorated_myfunc)
decorated_myfunc()
decorated_myfunc('args to decorated',4)

functools提供了一个修饰符wraps(),他会对所修饰的函数应用update_wrapper()。
运行结果:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值