标准库functools.wraps的使用方法

首先请看以下代码app

  # 定义一个最简单的装饰器函数

  def user_login_data(f):
    def wrapper(*args, **kwargs):
      return f(*args, **kwargs)spa

    return wrapper装饰器

  # 用装饰器装饰如下两个函数
  
  @user_login_data
  def num1():
    print("aaa")
tools



  @user_login_data
  def num2():
    print("bbbb")解决方案

  if __name__ == '__main__':
    print(num1.__name__)
    print(num2.__name__)data

 以上代码的输出结果为:return

    wrapperps

    wrapper

由此函数使用装饰器时,函数的函数名即 __name__已经被装饰器改变.

通常定义装饰器的话能够不用考虑这点,可是若是多个函数被两个装饰器装饰时就报错,由于两个函数名同样,第二个函数再去装饰的话就报错.

解决方案就是引入  functools.wraps  ,以上代码的解决以下: 

    

    def user_login_data(f):
    @functools.wraps(f)
      def wrapper(*args, **kwargs):
        return f(*args, **kwargs)

      return wrapper

增长@functools.wraps(f), 能够保持当前装饰器去装饰的函数的 __name__ 的值不变

以上输出结果就是: 

    num1

    num2

相关文章
相关标签/搜索