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

方法一

#!/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()

Logo

CSDN联合极客时间,共同打造面向开发者的精品内容学习社区,助力成长!

更多推荐