python装饰器实现耗时时间,第几次调用,以及缓存的功能

需求编写一个装饰器,用来装饰test函数

装饰器具有以下功能:

1、test调用时,可以打印是第几次调用  

2、test如果多次调用传入的参数相同,则第二次不需要耗时,直接返回结果,即实现简单缓存功能

3、test调用时,可以打印耗时时间

import time 



count = 0
cache = {}

def decorate(fn):
    

    def inner(*args, **kwargs):
        start = time.time()

        global count
        global cache
        if (args, str(kwargs)) in cache.keys():

            return cache[(args, str(kwargs))]
            data = fn(*args, **kwargs)
            cache[(args, str(kwargs))] = data  # 这里由于**kwargs是字典,而python字典的Key要是字符串类型,所以就str(kwargs)
            end = time.time()
            print("第%d次被调用" % (count) )
            print("耗时时间: ", end - start)
        return data
     return inner

@decorate
def test(word):
     time.sleep(2)
     return word.upper()


 if __name__ == '__main__':
     print(test("hero"))
     print(test("hero"))
    print(test("her"))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值