带你了解下python中统计程序运行时间的方法

本文介绍了四种统计Python程序运行时间的方法:1) 使用datetime模块;2) 通过time模块测量循环时间;3) 应用time.perf_counter()或time.process_time();4) 时间it模块的timeit.default_timer()。这些技巧有助于优化代码效率。
摘要由CSDN通过智能技术生成

前言:我们在写程序过程中通常都会要求程序运行时间最短,那么我们怎么来统计程序的耗时情况呢?这里有几个方法供大家参考!

方法一

#!/usr/bin/env python
# _*_ coding: utf-8 _*_
# @project : xmindtotable
# @File    : test.py
# @Date    : 2021/4/6 9:35 上午
# @Author  : 李文良
import datetime

starttime = datetime.datetime.now()

endtime = datetime.datetime.now()
print(endtime - starttime)

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

方法二

#!/usr/bin/env python
# _*_ coding: utf-8 _*_
# @project : xmindtotable
# @File    : test.py
# @Date    : 2021/4/6 9:35 上午
# @Author  : 李文良
from time import *

begin_time = time()
i = 0
while i < 100:
    print(i)
    i += 1

end_time = time()
run_time = end_time - begin_time
print('该循环程序运行时间:', run_time)

调用time模块的time()函数 :用来获取当前的时间,返回的单位是秒

方法三

#!/usr/bin/env python
# _*_ coding: utf-8 _*_
# @project : xmindtotable
# @File    : test.py
# @Date    : 2021/4/6 9:35 上午
# @Author  : 李文良
import time
start = time.perf_counter()  # python2请用time.clock(),Python 3.8 已移除 clock() 方法 可以使用 time.perf_counter() 或 time.process_time() 方法替代

end = time.process_time()
print(end - start)

Python 3.8 已移除 clock() 方法 可以使用 time.perf_counter() 或 time.process_time() 方法替代。

Python time clock() 函数以浮点数计算的秒数返回当前的CPU时间。用来衡量不同程序的耗时,比time.time()更有用。

这个需要注意,在不同的系统上含义不同。在UNIX系统上,它返回的是"进程时间",它是用秒表示的浮点数(时间戳)。而在WINDOWS中,第一次调用,返回的是进程运行的实际时间。而第二次之后的调用是自第一次调用以后到现在的运行时间。(实际上是以WIN32上QueryPerformanceCounter()为基础,它比毫秒表示更为精确)

注:程序执行时间=cpu时间 + io时间 + 休眠或者等待时间

方法四

#!/usr/bin/env python
# _*_ coding: utf-8 _*_
# @project : xmindtotable
# @File    : test.py
# @Date    : 2021/4/6 9:35 上午
# @Author  : 李文良
import timeit

start = timeit.default_timer()
end = timeit.default_timer()
print(end - start)

在 Unix 系统中,建议使用 time.time(),在 Windows 系统中,建议使用 time.clock()
实现跨平台的精度性可以使用timeit.default_timer()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

李先森&Mr.Li

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值