python 精确测量程序运行时间

这是我的推广信息,以激励自己更好的分享自己的知识和经验!也希望看到的你能够多多支持,谢谢!

1. 滴滴云AI大师:

目前滴滴云正在大力推广自己的云计算服务,需要购买的朋友们用我的AI大师码 「2049」在滴滴云上购买 GPU / vGPU / 机器学习产品可额外享受 9 折优惠,点击这里前往滴滴云官网

问题介绍

在python下面有很多计算代码运行时间的方法。最常见的就是time.time()time.clock()模块。但是有人会问哪一个最好呢?这里众说纷纭,但其实这两个都不是最好的。或者说,你不应该用他们两来测试代码块的运行时间。
因为在不同的系统下,这两个函数具有不同的精度和表现。具体可以参考:

并且不同的python版本,推荐的方式也是不一样的。

大概总结一下:

  • time.time()和time.clock()在windows和Lniux上具有不同的精度
  • 大多数时候,time.clock()都会更好。然而,如果你的代码包含在其他硬件(比如GPU)上运行的部分,time.clock()无法统计那部分时间。你只能使用time.time()
  • 任何时候,两个函数都会测量其它多余的不可避免的部分的时间,虽然time.time()更严重
  • 在python3.3之后,time.clock已经被抑制,推荐使用time.process_time() 或者 time.perf_counter() 取代。
  • python内置的timeit.default_timer()或根据不同的操作系统和python版本,选择最为合适的计时器。

最终的答案

请使用timeit.default_timer()来计算代码块的运行时间。该模块综合考虑操作系统、python版本选择精度最高的计时器,输出结果为秒。代码如下:

from timeit import default_timer as timer

tic = timer()
# 待测试的代码
toc = timer()

print(toc - tic) # 输出的时间,秒为单位
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值