设为首页 收藏本站
查看: 1013|回复: 0

[经验分享] Python---装饰器

[复制链接]

尚未签到

发表于 2018-8-12 12:10:18 | 显示全部楼层 |阅读模式
# 装饰器  
# 由于函数也是一个对象,而且函数对象可以被赋值给变量,所以,通过变量也能调用该函数
  

  

  
def now():
  
    print('2017-08-07')
  

  
f = now
  
f()
  

  
# 函数对象有一个__name__属性,可以拿到函数的名字
  

  
print(now.__name__)
  
print(f.__name__)
  

  
# 假设我们要增强now()函数的功能
  
# 比如,在函数调用前后自动打印日志,但又不希望修改now()函数的定义,这种代码运行期间动态增加功能的方式,称之为"装饰器"(Decorator)
  

  
# 本质上,decorator就是一个返回函数的高阶函数
  
# 定义一个能打印日志的decorator
  

  

  
def log(func):
  
    def wrapper(*args, **kw):
  
        print('call %s():' % func.__name__)
  
        return func(*args, **kw)
  
    return wrapper
  

  
# decorator接受一个函数作为参数,并返回一个函数
  
# 我们要借助Python的语法,把decorator置于函数的定义处
  

  

  
@log
  
def now():
  
    print('2017-08-07')
  

  
now()
  

  
# 把@log放到now()函数的定义处,相当于执行了语句 now = log(now)
  
# 由于log()是一个decorator,返回一个函数,所以,原来的now()函数依然存在,只是现在同名的now变量指向了新的函数
  
# 于是调用now()将执行新函数,即在log()函数中返回的wrapper()函数
  

  
# wrapper()函数的参数定义是(*args, **kw),因此,wrapper()函数可以接受任意参数的调用
  
# 在wrapper()函数内,首先打印日志,再紧接着调用原始函数
  

  
# 如果decorator本身需要传入参数,那就需要编写一个返回decorator的高阶函数,写出来会更复杂
  
# 自定义log的文本
  

  

  
def log(text):
  
    def decorator(func):
  
        def wrapper(*args, **kw):
  
            print('%s %s():' % (text, func.__name__))
  
            return func(*args, **kw)
  
        return wrapper
  
    return decorator
  

  

  
@log('execute')
  
def now2():
  
    print('2017-08-07')
  

  
now2()
  

  
# 和两层嵌套的decorator相比,3层嵌套的效果是  now = log('execute')(now)
  
# 上面的语句,首先执行log('execute'),返回的是decorator函数,再调用返回的函数,参数是now函数,返回值最终是wrapper函数

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-550606-1-1.html 上篇帖子: (记录)初学python篇:四 下篇帖子: Python IDE介绍
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表