def debug(func):
def wrapper(*args, **kwargs): # 多个参数
# def wrapper(something): # 指定一样的参数
print("[DEBUG]: enter {}()".format(func.__name__))
return func(*args, **kwargs)
return wrapper # 返回包装过函数
@debug
def say(something):
print("hello {}!".format(something))
say('A');
注:
装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。它经常用于有切面需求的场景,比如:插入日志、性能测试、事务处理、缓存、权限校验等场景。装饰器是解决这类问题的绝佳设计,有了装饰器,我们就可以抽离出大量与函数功能本身无关的雷同代码并继续重用。