位置: IT常识 - 正文

python中的装饰器的使用实战

编辑:rootadmin

推荐整理分享python中的装饰器的使用实战,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

1、装饰器的理解

装饰器是将一个函数镶嵌在另一个函数中进行重复使用的目的,不改变其结构,增加函数的使用方式,但是不用写过多冗余的代码;

装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。

通常用到的功能:1.引入日志;2.函数执行时间统计;3.执行函数前预备处理;4.执行函数后清理功能;5.权限校验;6.缓存

2、实现原理与通用写法

咱们可以从一个简单的记录函数运行时间的简单装饰器,举一反三,推导出一个通用的装饰器写法

importtimedeftimer(func):'''记录方法运行时间的装饰器:paramfunc:方法:return:函数对象'''defdeco(*args,**kwargs):startTime=time.time()f=func(*args,**kwargs)endTime=time.time()msecs=(endTime-startTime)*1000print("timeis%dms"%msecs)returnf#如果func有返回值得话,需要在此return回去,否则,默认返回值为None,一般默认都返回returndeco@timerdeftest(parameter):print("testisrunning!")time.sleep(1)return"Returnedvalue"#该函数有返回值,所以需要在装饰器中的deco方法中写返回值t=test('aa')print(t)

这是一个很简单的通用的记录时间的装饰器,从而推导出一个通用的装饰器写法:

deffunc_name(func):#自定义装饰器函数名defdeco(*args,**kwargs):#将所有参数原封不动的进行传递print("在这个分割线之上写函数运行前的操作")#-----------分割线-----------f=func(*args,**kwargs)#-----------分割线-----------print("在这个分割线之后,return之前,写函数运行后的操作")returnf#如果func有返回值得话,需要在此return回去,否则,默认返回值为None,一般默认都返回returndeco@func_namedeftest(parameter):#8print("testisrunning!")time.sleep(1)return"Returnedvalue"#该函数有返回值,所以需要在装饰器中的deco方法中写返回值t=test('aa')print(t)

ok 装饰器到此可以完事了,一般情况下都能满足需求了,网上看那么多原理,有点儿浪费时间,我偏向实操型,实在不喜欢啰嗦那么多,就是干。

当然在开发过程中, 我们可能会遇到一些特殊情况,比如参数问题

python中的装饰器的使用实战

1、给装饰器函数代参数(通用)

2、将执行函数的参数拆分计算等(比如:1000w的数据,拆分成100份执行等)(定制)

那就按顺序来

1、写一个代参数的装饰器

deflogging(level):defwrapper(func):definner_wrapper(*args,**kwargs):print("[{level}]:enterfunction{func}()".format(level=level,func=func.__name__))returnfunc(*args,**kwargs)returninner_wrapperreturnwrapper@logging(level='INFO')defsay(something):print("say{}!".format(something))#如果没有使用@语法,等同于#say=logging(level='INFO')(say)@logging(level='DEBUG')defdo(something):print("do{}...".format(something))if__name__=='__main__':say('hello')do("mywork")

发现:就是在上面的通用的模板上又套了一层!!!,然后拿到里面的参数即可! so easy!!!

2、写一个参数拆分的装饰器,这个就稍微有点定制型了,不能像上面的一样通用了,举个 栗子:

deffunc_name(func):#自定义装饰器函数名defdeco(*args,**kwargs):#将所有参数原封不动的进行传递print(args[0])f_list=[]foriinrange(0,args[0],100000):print(i)f_list.append(func(i))#f_list#这儿应该按照既定规则,继续对这个结果进行拼接,如果是写文件、入库等操作,可以不用returnreturnf_list#这儿如果有返回值得话,应该是returndeco@func_namedeftest(parameter):#8print("testisrunning!")time.sleep(1)return"Returnedvalue"#该函数有返回值,所以需要在装饰器中的deco方法中写返回值t=test(1000000)print(t)

可以看出来,这个的定制性稍微高点,不通用,但是我们实现了我们的需求,所以,我们最应该理解并学会的是怎么用!!!

可以看出来,这个的定制性稍微高点,不通用,但是我们实现了我们的需求,所以,我们最应该理解并学会的是怎么用!!!

下面在介绍一下基于类实现的装饰器,那问题来了,我是实战派,我并没有用类装饰器的需求,所以,当个大盗吧,以后用到了不至于瞎找了!!!

装饰器函数其实是这样一个接口约束,它必须接受一个callable对象作为参数,然后返回一个callable对象。在Python中一般callable对象都是函数,但也有例外。只要某个对象重载了__call__()方法,那么这个对象就是callable的。

classTest():def__call__(self):print'callme!'t=Test()t()#callme

像__call__这样前后都带下划线的方法在Python中被称为内置方法,有时候也被称为魔法方法。重载这些魔法方法一般会改变对象的内部行为。上面这个例子就让一个类对象拥有了被调用的行为。

回到装饰器上的概念上来,装饰器要求接受一个callable对象,并返回一个callable对象(不太严谨,详见后文)。

那么用类来实现也是也可以的。我们可以让类的构造函数__init__()接受一个函数,然后重载__call__()并返回一个函数,也可以达到装饰器函数的效果。

classlogging(object):def__init__(self,func):self.func=funcdef__call__(self,*args,**kwargs):print"[DEBUG]:enterfunction{func}()".format(func=self.func.__name__)returnself.func(*args,**kwargs)@loggingdefsay(something):print"say{}!".format(something)

带参数的类装饰器

如果需要通过类形式实现带参数的装饰器,那么会比前面的例子稍微复杂一点。那么在构造函数里接受的就不是一个函数,而是传入的参数。通过类把这些参数保存起来。

classlogging(object):def__init__(self,level='INFO'):self.level=leveldef__call__(self,func):#接受函数defwrapper(*args,**kwargs):print"[{level}]:enterfunction{func}()".format(level=self.level,func=func.__name__)func(*args,**kwargs)returnwrapper#返回函数@logging(level='INFO')defsay(something):print"say{}!".format(something)
本文链接地址:https://www.jiuchutong.com/zhishi/310802.html 转载请保留说明!

上一篇:在dedecms织梦模板文章内容页调用关键词增加链接(如何用织梦在本地搭建网站)

下一篇:java同步的使用条件(java同步操作)

  • 小规模收到专票怎么处理
  • 一般纳税人内账税金的处理
  • 个体工商户个人经营所得税优惠政策
  • 餐饮设备租赁服务属于
  • 印花税应纳税额计算方法
  • 生日卡片好看吗
  • 变动成本法的计算公式有哪些
  • 应税项目和非应税项目起征点一样吗
  • 发票没金额能开吗
  • 高温费国家有规定,一定要支付吗?
  • 其他应收款可以在贷方吗
  • 如何做好服务 服务行业
  • 年终奖如何合理发放
  • 计算并分摊本月利润
  • 营改增后税目税率表
  • 小规模公司没有进项票 开票需要交什么税
  • 有开发票就要交印花税吗?
  • 企业所得税一般纳税人是怎么缴纳的
  • 增值税普通发票需要交税吗
  • 增值税确认平台一直显示该网站出现问题
  • 增值税专票代码TZD0085什么意思
  • 外经证过期没报验
  • 房屋交易税费的计算
  • 劳务费个人所得税税率
  • 计算所得税时扣除增值税附加怎么算
  • 个税上月没有申报当月可以补报么
  • 企业收到的政府补贴,怎么入账
  • 出售使用过的设备
  • 什么是BIOS设置界面
  • 两免三减半条件
  • 升级w10系统
  • 贷款发生减值
  • axios怎么使用
  • 辞退员工补偿标准是n+1还是2n
  • 短期借款会计分录例题
  • yolov5损失
  • 企业为员工缴纳社保标准及流程
  • vue element ui教程
  • 递延收益会计科目核算什么内容
  • 微信支付开发者平台
  • vue开发环境配置
  • 实收资本 增加
  • 本期进项税额明细表为什么数据一直出不来
  • 苹果响应机制
  • mongodb安装教程图解
  • 分公司税务登记流程与操作手册
  • 固定资产不计提残值可以吗
  • 百旺 税控盘
  • 待摊费用属于企业的债权
  • 应付帐款借方余额,但对方公司己注销
  • 应收账款在贷方为负数表示什么
  • 职工薪酬实际发生额忘记填会有风险吗
  • 对公允价值套期的认识
  • 增值税申报表中期初未缴税额指什么
  • 以银行存款支付所欠税金48000
  • 技能培训费属于哪个科目
  • 所得税汇算清缴前取得跨年发票
  • 劳动仲裁要出面吗
  • 外贸采购的职责
  • 员工拿发票报销账务处理
  • 如何在电子税务局变更办税人员
  • 现代服务业如何提高服务的效率和质量
  • 医院收费单可以当发票吗
  • 企业积分是什么意思
  • 银行对账单怎么打印
  • 数据库复制数据sql语句
  • win10系统预览版
  • android-x86安装
  • win7安装软件出现乱码
  • 电脑qq老是弹出fi
  • mac safari浏览器翻译功能
  • win10桌面图标排列设置
  • jquery实现密码和确认密码
  • css滑动门技术的步骤
  • 对于不回微信的人,这样做,尽显高情商!
  • node.js的理解
  • LinearLayout layout_weight解析
  • 小规模纳税人改成一般纳税人怎么改
  • 涉嫌虚开增值税专用发票罪
  • 税务注销了怎么查看纳税申报表
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设