美文网首页
Python装饰器

Python装饰器

作者: _PatrickStar | 来源:发表于2019-05-25 21:13 被阅读0次

代码主要模拟的功能:首先我们之前已经写好了几个功能,比如:add函数,vat函数。然后需求变更,需要我们记录一下每次功能代码执行的运行时间(这里简单的用time.sleep模拟了一下)。但是因为之前的功能代码已经写死了,所以先添加的功能要在此基础上实现却不能改变源代码结构,所以这时候就用到了@show_time方法将新的计算时间的功能以装饰器的形式加在之前写好的模块上。紧接着,又需要变更需求。希望可以在某些特定的功能模块运行时打印日志信息。于是再嵌套一层装饰器@logger(参数)。之所以不在show_time()上修改,加参数。原因也是因为show_time已经在生产环境,代码被多业务使用。不能修改,否则其他业务部门都要跟着修改,这不现实!

import time
def logger(flag=None):   #标志默认为空
    def show_time(f):
        def inner(*args,**kwargs):
            start = time.time()
            f(*args,**kwargs)
            end = time.time()
            print('spend: %s'%(end-start))
            if flag == 'true':
                print('日志记录成功')
        return inner
    return show_time


@logger('true')   #logger参数为true 表示打印日志
def add(*args,**kwargs):
    sum = 0
    for i in args:
        sum+=i
    print(sum)
    time.sleep(2)


@logger()
def vat():
    print('bar...')

add(2,3,4,6,6,a=3,b=6)    #调用
vat()

相关文章

  • 装饰器模式

    介绍 在python装饰器学习 这篇文章中,介绍了python 中的装饰器,python内置了对装饰器的支持。面向...

  • python中的装饰器

    python装饰器详解 Python装饰器学习(九步入门) 装饰器(decorator) 就是一个包装机(wrap...

  • [译] Python装饰器Part II:装饰器参数

    这是Python装饰器讲解的第二部分,上一篇:Python装饰器Part I:装饰器简介 回顾:不带参数的装饰器 ...

  • Python中的装饰器

    Python中的装饰器 不带参数的装饰器 带参数的装饰器 类装饰器 functools.wraps 使用装饰器极大...

  • Python进阶——面向对象

    1. Python中的@property   @property是python自带的装饰器,装饰器(decorat...

  • Python 装饰器填坑指南 | 最常见的报错信息、原因和解决方

    Python 装饰器简介装饰器(Decorator)是 Python 非常实用的一个语法糖功能。装饰器本质是一种返...

  • Python装饰器

    Python装饰器 一、函数装饰器 1.无参装饰器 示例:日志记录装饰器 2.带参装饰器 示例: 二、类装饰器 示例:

  • python3基础---详解装饰器

    1、装饰器原理 2、装饰器语法 3、装饰器执行的时间 装饰器在Python解释器执行的时候,就会进行自动装饰,并不...

  • 2019-05-26python装饰器到底是什么?

    装饰器例子 参考语法 装饰器是什么?个人理解,装饰器,是python中一种写法的定义。他仍然符合python的基本...

  • 2018-07-18

    Python装饰器 装饰,顾名思义,是用来打扮什么东西的。Python装饰...

网友评论

      本文标题:Python装饰器

      本文链接:https://www.haomeiwen.com/subject/vhzzzqtx.html