当前位置: 首页 > 科技观察

装饰器的那些事儿浅析

时间:2023-03-20 20:00:09 科技观察

1.装饰器的简单定义外层函数返回内层函数的引用,内层函数引用外层函数的变量。2、装饰器的作用一般来说,装饰器的作用是在不改变已有功能代码的情况下,为功能增加新的功能。defrun():print('Icanrun')fun()现在我想在原来的功能基础上加一个功能:我会唱歌。这时候使用装饰器就可以很方便的帮我们实现这个功能。3.实例理解(1)不传参的装饰器defouter(fun):definner():fun()//fun是外层函数的变量,returninner//inner是在内层使用的参考内层函数(2)传参装饰器:deffunc(fun):defadd(*args,**kwarge):returnfun(*args,**kwargs)returnadd至此对基本格式有了一定的了解装饰器的,可以直接把函数写上去。下面实现了文章开头的Icansing函数defouter(fun):definner(*args,**kwarge):print("Icansing")returnfun(*args,**kwarge)returninner4.如何实现使用装饰器方法一:使用@符号+装饰器名称放在你要装饰的函数的上一行@outerdefrun():print('Iwillrun')run()方法二:defrun():print('IWillrun')run=outer(run)#相当于@outerrun()最后的打印结果是:IcansingandIcanrun如果我想知道传递的参数是什么有趣的是,我可以在装饰器中使用以下方法:defouter(fun):a=1definner(*args,**kwarge):#args是一个数组,kwargs是一个字典print(fun.__name__)#printthenamefunprint("Icansing")returnfun(*args,**kwarge)returninner接收到的函数的一部分,但是如果我们print(run.__name__,6666666)输出结果是inner,而不是我们想要的运行,函数这里被warpTheFunction取代。它覆盖了我们函数的名称和文档字符串。解决方法如下:fromfunctoolsimportwrapsdefouter(fun):@wraps(fun)definner(*args,**kwargs):print(fun.__name__,11111111111)print("Icansing")returnfun(*args,**kwargs))returningner@outerdefrun():print('Iwillrun')print(run.__name__,6666666)//输出结果为run6666665.实现装饰器defsubuser_keymanage(view_func):'''功能是实现判断用户管理权限'''def_wrapper_view(request,*args,**kwargs):user=request.user#一个Customer对象,包括用户名/密码等信息customer=user.customer.customer_id#user'sidselect_status=get_curuser_permission(user=user,customer=customer)#调用函数返回的值有两种:0和1ifnotselect_status:#如果返回0表示没有权限,返回错误码。(request):params=json.loads(request.body)#获取卡片前端传过来的参数user_id_only=params.get("user_id")#获取用户的id值中间代码忽略...returnrender_response(request,ErrorCode.FAILED)6.装饰器总结装饰器可以大大减少代码重用,这在代码规范中非常重要。以上就是装饰器的基础知识。即使没有基础,按照作者的思路,应用固定的格式,不需要完全理解,只要按照流程一步步来,也能写出高端大气的装饰器。恭喜!前言高能请注意:装饰器传参,三层嵌套函数一般用的比较少,其实也不难,看一层,上面说了,只是作为增广见闻。importloggingdefuse_logging(level):defdecorator(func):defwrapper(*args,**kwargs):iflevel=="warn":logging.warn("%sisrunning"%func.__name__)eliflevel="info":logging.info("%sisrunning"%func.__name__)returnfunc(*args)returnwrapperreturndecorator@use_logging(level="warn")defffoo(name='foo'):print("iam%s"%name)foo()iamfooWARNING:root:foo正在运行