装饰器实现计算函数的运行时间

本文介绍装饰器在Python中的应用,通过一个具体实例展示如何使用装饰器来计算函数的执行时间,这是一种不修改原函数代码的情况下增强其功能的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

装饰器实现计算函数的运行时间

何为装饰器
  • 装饰器其实就是一个函数,该函数有一个参数(函数类型),返回一个闭包
  • 在返回的闭包中调用传递进来的函数,然后在调用函数的前后就可以添加内容
作用:
  • 当需要改变一个函数原有的功能时,但是不想/不能改变原来的函数,可以通过装饰器解决
计算函数执行时间的装饰器
import functools
import time

def run_time(fn):
    @functools.wraps(fn)
    def wrapper(*args, **kw):
        start = time.time()
        res = fn(*args, **kw)
        print('%s 运行了 %f 秒' % (fn.__name__, time.time() - start))
        return res

    return wrapper
   

#测试
@run_time
def test(n):
    time.sleep(n)
    print("运行结束了")

test(3)

测试结果
运行结束了
test 运行了 3.000641
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值