Python中统计程序运行时间的几种方法

装饰器法

此方法不改变被装饰函数的返回值

#!/usr/bin/python
# -*- coding: utf-8 -*-  
import datetime
import functools
import time


def time_me(func):
    '''
    @summary: cal the time of the fucntion
    @param : None
    @return: return the res of the func
    '''

    def wrapper(*args, **kw):
        start_time = datetime.datetime.now()
        res = func(*args, **kw)
        over_time = datetime.datetime.now()
        print ('{0} run time is {1}'.format(func.__name__, (over_time - start_time).total_seconds()))
        return res

    return wrapper


@time_me
def test1():
    time.sleep(1)
    return 'aaa'


A = test1()

print (A)

datetime.datetime.now()方法:

#!/usr/bin/python
# -*- coding: utf-8 -*-
from datetime import datetime
starttime = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
print (starttime)
#long running
#do something other
endtime = datetime.now().strftime('%Y-%m-%d %H:%M:%S')
print (endtime)
# 2022-03-21 15:08:06
# 2022-03-21 15:08:06

datetime.datetime.now()获取的是当前时间,在程序执行结束之后,这个方式获得的时间差值为程序执行的时间。

time.time()方法:

start = time.time()
#long running
#do something other
end = time.time()
print (end-start)

time.time()获取自纪元以来的当前时间(以秒为单位)。如果系统时钟提供它们,则可能存在秒的分数。所以这个地方返回的是一个浮点型类型。这里获取的也是程序的执行时间。

time.clock()方法:

start = time.clock()
#long running
#do something other
end = time.clock()
print end-start

time.clock()返回程序开始或第一次被调用clock()以来的CPU时间。 这具有与系统记录一样多的精度。返回的也是一个浮点类型。这里获得的是CPU的执行时间。 
注:程序执行时间=cpu时间 + io时间 + 休眠或者等待时间

  • 4
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值