浅析装饰器的那些事儿

简介: 浅析装饰器的那些事儿

一、装饰器的简单定义


外层函数返回里层函数的引用,里层函数引用外层函数的变量。


二、装饰器的作用


通俗来讲装饰器的作用就是在不改变已有函数代码前提下,为该函数增加新的功能。

def run():   print('我会跑')fun()


现在我想在原有函数的基础上新增一个功能:我会唱歌。这个时候利用装饰器则轻松可以帮我们实现这个功能。


三、实例理解


(1)不传参的装饰器

def outer(fun):   def inner():      fun()  //fun是外层函数的变量,在inner里面用   return inner //inner就是里层函数的引用


(2)传递参数的装饰器:

def func(fun):   def add(*args,**kwarge):      return fun(*args,**kwargs)   return add


现在对于装饰器的基本格式有一定的了解,就可以直接写函数了。下面实现文章开头的 我会唱歌 的功能

def outer(fun):    def inner(*args, **kwarge):        print("我会唱歌")        return fun(*args, **kwarge)    return inner


四、如何使用装饰器


方法一:使用@符号+装饰器的名字   把它放在想要装饰函数的上一行即可@outerdef run():   print('我会跑')   run()
方法二:def run():    print('我会跑')
run=outer(run)   #就等价于@outerrun()
最终打印结果是:我会唱歌我会跑


如果我想知道fun 传递的参数是什么,在装饰器内部可以使用如下方式:

def outer(fun):    a = 1    def inner(*args, **kwarge): # args是一个数组,kwargs一个字典        print(fun.__name__) #打印fun接收的函数的名字        print("我会唱歌")        return fun(*args, **kwarge)    return inner


但是如果我们 print(run.__name__,6666666) 输出的结果是inner,并不是我们想要的run,这里的函数被warpTheFunction替代了。它重写了我们函数的名字和注释文档(docstring)。解决方法如下:

from functools import wraps
def outer(fun):    @wraps(fun)    def inner(*args, **kwargs):        print(fun.__name__,11111111111)        print("我会唱歌")        return fun(*args, **kwargs)    return inner
@outerdef run():   print('我会跑')    print(run.__name__,6666666)  //输出结果为 run 666666

 

五、自己实现装饰器


def subuser_keymanage(view_func):    '''功能是实现用户管理权限的判定'''    def _wrapper_view(request, *args, **kwargs):        user = request.user #一个Customer对象,包含了用户名/密码等信息        customer = user.customer.customer_id #用户的id        select_status = get_curuser_permission(user=user, customer=customer)#调用函数返回的值有两种0和1        if not select_status:#如果返回0表示没有权限,返回错误码            return render_response(request, ErrorCode.FAILED)        return view_func(request, *args, **kwargs)    return _wrapper_view


@subuser_keymanage def generate_subuser_ak_sk(request):    params = json.loads(request.body) #获取卡前端传递的参数    user_id_only = params.get("user_id") #获取用户表示id值    中间代码就忽略了......    return render_response(request, ErrorCode.FAILED)


六、装饰器小结


通过装饰器很大程度上可以减少代码的复用,在代码规范中这一点是很重要的。

以上就是装饰器的基本知识,即便没有任何基础,按照作者的思路,套用固定的格式,不需要完全理解,只要按照流程一步一步就能写出高端大气上档次的装饰器了,恭喜你!

前方高能请注意:装饰器传参,三层嵌套函数一般用的比较少,其实也不难,一层一层看,跟上文讲的一样,仅作为知识的拓宽。

import loggingdef use_logging(level):    def decorator(func):        def wrapper(*args, **kwargs):            if level == "warn":                logging.warn("%s is running" % func.__name__)            elif level == "info":                logging.info("%s is running" % func.__name__)            return func(*args)        return wrapper
    return decorator
@use_logging(level="warn")def foo(name='foo'):    print("i am %s" % name)
foo()


i am fooWARNING:root:foo is running


如果在操作过程中有任何问题,记得下面留言,我们看到会第一时间解决问题。


相关文章
|
12月前
装饰器:装饰器为主,闭包和高阶函数为辅
装饰器:装饰器为主,闭包和高阶函数为辅
|
7天前
|
人工智能 运维 安全
|
5天前
|
人工智能 异构计算
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
敬请锁定《C位面对面》,洞察通用计算如何在AI时代持续赋能企业创新,助力业务发展!
|
6天前
|
机器学习/深度学习 人工智能 自然语言处理
B站开源IndexTTS2,用极致表现力颠覆听觉体验
在语音合成技术不断演进的背景下,早期版本的IndexTTS虽然在多场景应用中展现出良好的表现,但在情感表达的细腻度与时长控制的精准性方面仍存在提升空间。为了解决这些问题,并进一步推动零样本语音合成在实际场景中的落地能力,B站语音团队对模型架构与训练策略进行了深度优化,推出了全新一代语音合成模型——IndexTTS2 。
602 21
|
12天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
968 110
|
6天前
|
人工智能 测试技术 API
智能体(AI Agent)搭建全攻略:从概念到实践的终极指南
在人工智能浪潮中,智能体(AI Agent)正成为变革性技术。它们具备自主决策、环境感知、任务执行等能力,广泛应用于日常任务与商业流程。本文详解智能体概念、架构及七步搭建指南,助你打造专属智能体,迎接智能自动化新时代。