简单了解python装饰器原理及使用方法


Posted in Python onDecember 18, 2019

这篇文章主要介绍了简单了解python装饰器原理及使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

如果你接触 Python 有一段时间了的话,想必你对 @ 符号一定不陌生了,没错 @ 符号就是装饰器的语法糖。

装饰器的使用方法很固定:

先定义一个装饰函数(帽子)(也可以用类、偏函数实现)

再定义你的业务函数、或者类(人)最后把这顶帽子带在这个人头上

Python装饰器就是用于拓展原来函数功能的一种函数,目的是在不改变原函数名(或类名)的情况下,给函数增加新的功能。

这个函数的特殊之处在于它的返回值也是一个函数,这个函数是内嵌“原“”函数的函数。

# 有两个已经实现的方法
def f1():
  print("正常流程1")
def f2():
  print("正常流程2")

# 一、需求 我们在每个方法内部加入一个需求
# 定义了一个函数f3,它的参数是一个函数,然后给这个函数嵌入print("需求")。但是想要拓展这一千万个函数功能,
# 就是要执行一千万次f3()函数,所以这样并不理想!接下来,我们可以试着用装饰器来实现,先看看装饰器最原始的面貌。
def f3():
  print("需求")

def f1():
  f3()
  print("正常流程1")

def f2():
  f3()
  print("正常流程2")
# 二、需求 我们现在不需要之前的那个需求了 需要删除f3()

def f1():
  print("正常流程1")

def f2():
  print("正常流程2")

# 根据 python开放-封闭的原则,有些时候核心代码并不可以直接去改,所以在不改动原代码的情况下,我们可以再定义一个函数
# 这里的f3函数就是最原始的装饰器,它的参数是一个函数,然后返回值也是一个函数。
#
# 其中作为参数的这个函数f1()就在返回函数f4()的内部执行。然后在函数f1()前面加上@f3,
#
# f1()函数就相当于注入增加“需求”功能,现在只要调用f1(),它就已经变身为增加“需求”的函数了,
# (不需要重复执行原函数)。
def f3(fn):
def f4():


print("需求")
   fn()
  return f4

@f3
def f1():
  print("正常流程1")

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在服务器端实现无间断部署Python应用的教程
Apr 16 Python
Python向日志输出中添加上下文信息
May 24 Python
python3+mysql查询数据并通过邮件群发excel附件
Feb 24 Python
numpy判断数值类型、过滤出数值型数据的方法
Jun 09 Python
Python全局变量与局部变量区别及用法分析
Sep 03 Python
Python3实现取图片中特定的像素替换指定的颜色示例
Jan 24 Python
Python面向对象程序设计示例小结
Jan 30 Python
Python使用selenium + headless chrome获取网页内容的方法示例
Oct 16 Python
Python PyPDF2模块安装使用解析
Jan 19 Python
pycharm通过ssh连接远程服务器教程
Feb 12 Python
Python Django ORM连表正反操作技巧
Jun 13 Python
openstack中的rpc远程调用的方法
Jul 09 Python
修改Pandas的行或列的名字(重命名)
Dec 18 #Python
Python3直接爬取图片URL并保存示例
Dec 18 #Python
python 实现图片上传接口开发 并生成可以访问的图片url
Dec 18 #Python
Python谱减法语音降噪实例
Dec 18 #Python
利用PyCharm操作Github(仓库新建、更新,代码回滚)
Dec 18 #Python
使用python 对验证码图片进行降噪处理
Dec 18 #Python
如何使用Python多线程测试并发漏洞
Dec 18 #Python
You might like
php入门学习知识点五 关于php数组的几个基本操作
2011/07/14 PHP
php无限级分类实现方法分析
2016/10/19 PHP
JavaScript中出现乱码的处理心得
2009/12/24 Javascript
javascript getElementsByTagName
2011/01/31 Javascript
关于jquery.validate1.9.0前台验证的使用介绍
2013/04/26 Javascript
使用js对select动态添加和删除OPTION示例代码
2013/08/12 Javascript
js实现幻灯片效果(基于jquery插件)
2013/11/05 Javascript
JavaScript中的常见问题解决方法(乱码,IE缓存,代理)
2013/11/28 Javascript
js+HTML5基于过滤器从摄像头中捕获视频的方法
2015/06/16 Javascript
JavaScript中this的9种应用场景及三种复合应用场景
2015/09/12 Javascript
JS+CSS实现下拉刷新/上拉加载插件
2017/03/31 Javascript
解决Vue页面固定滚动位置的处理办法
2017/07/13 Javascript
在vue中,v-for的索引index在html中的使用方法
2018/03/06 Javascript
在vue项目中正确使用iconfont的方法
2018/09/28 Javascript
node和vue实现商城用户地址模块
2018/12/05 Javascript
详解Vue、element-ui、axios实现省市区三级联动
2019/05/07 Javascript
微信小程序开发实现消息推送
2020/11/18 Javascript
详解Vue.js 作用域、slot用法(单个slot、具名slot)
2019/10/15 Javascript
浅谈vue使用axios的回调函数中this不指向vue实例,为undefined
2020/09/21 Javascript
如何手动实现一个 JavaScript 模块执行器
2020/10/16 Javascript
Python中的左斜杠、右斜杠(正斜杠和反斜杠)
2016/08/30 Python
python判断一个集合是否为另一个集合的子集方法
2018/05/04 Python
Python小整数对象池和字符串intern实例解析
2020/03/21 Python
keras中的卷积层&池化层的用法
2020/05/22 Python
Opencv图像处理:如何判断图片里某个颜色值占的比例
2020/06/03 Python
Python魔术方法专题
2020/06/19 Python
通过一张图教会你CSS3倒影的实现
2017/09/26 HTML / CSS
加拿大时尚床上用品零售商:QE Home | Quilts Etc
2018/01/22 全球购物
Android面试题及答案
2015/09/04 面试题
网站编辑求职信
2013/10/17 职场文书
捐书寄语赠言
2014/01/18 职场文书
报关员个人职业生涯规划书
2014/03/12 职场文书
三严三实民主生活会发言稿
2014/10/13 职场文书
小学教师年度个人总结
2015/02/05 职场文书
信息技术远程培训心得体会
2016/01/09 职场文书
“爱眼护眼,提前预防近视”倡议书3篇
2019/10/30 职场文书