百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Python计算程序运行时间的六种方法

off999 2024-09-13 13:30 46 浏览 0 评论

  1. datetime.datetime.now() 方法
  • 返回表示当前地方时的 date 和 time 对象。
  • 该方法会在可能的情况下提供比通过 time.time() 时间戳所获时间值更高的精度。
start_time = datetime.datetime.now()
time.sleep(2)
end_time = datetime.datetime.now()
print(end_time1-start_time1)
>>> 0:00:00.258168
  1. time.time() 方法
  • 返回自纪元以来的秒数作为浮点数,但是时期的具体日期和闰秒的处理取决于使用的平台。比如:在Windows和大多数Unix系统上,纪元是1970年1月1日00:00:00(UTC),并且闰秒不计入自纪元以来的秒数,这也通常被称为Unix时间。
  • 时间总是作为浮点数返回,但并非所有系统都提供高于1秒的精度。
  • 使用 time_ns() 以避免 float 类型导致的精度损失。
  1. time.perf_counter() 方法

(以小数表示的秒为单位)返回一个性能计数器的值,即用于测量较短持续时间的具有最高有效精度的时钟。 它会包括睡眠状态所消耗的时间并且作用于全系统范围。 两次调用之间的差值才是有效的。

  1. time.process_time() 方法

(以小数表示的秒为单位)返回当前进程的系统和用户 CPU 时间的总计值。 它不包括睡眠状态所消耗的时间。 根据定义它只作用于进程范围。

  1. timeit模块,提供了一种简单的方法来计算一小段 Python 代码的耗时。
import timeit
t = timeit.timeit('"-".join(str(n) for n in range(100))', number=10000)
print(t)
  • 官方文档:https://docs.python.org/zh-cn/3/library/timeit.html#timeit-examples
  • 要让 timeit 模块访问你定义的函数,你可以传递一个包含 import 语句的 setup 参数:
print(timeit.timeit("test()", setup="from __main__ import test"))
  • 另一种选择是将 globals() 传递给 globals 参数,这将导致代码在当前的全局命名空间中执行。这比单独指定 import 更方便
print(timeit.timeit('[func(42) for func in (f,g,h)]', globals=globals()))
  1. %time
  • %time要在ipython下才可以使用。(Jupyter Notebook也是可以用的)
  • %time可以测量一行代码执行的时间
  • %%time可以测量多行代码执行的时间
  • %%timeit可以测量多行代码多次执行后的平均时间(运行 7 轮,每轮 10000 次取平均时间)
%time [x for x in range(1000)]
%%time
li = []
for i in range(1000):
    li.append(i ** 2)
%%timeit
li = []
for i in range(1000):
    li.append(i ** 2)

测试代码:

import time
import timeit
import datetime

def sum():
    s = 0
    for i in range(10000000):
        s += i

start_time1 = datetime.datetime.now()
start_time2 = time.time()
start_time3 = time.perf_counter()
start_time4 = time.process_time()

# 这两种方式都无法正常运行,程序没有任何输出
# t = timeit.timeit('sum()', setup="from __main__ import sum")
# t = timeit.timeit('sum()', globals=globals())
sum()

end_time1 = datetime.datetime.now()
end_time2 = time.time()
end_time3 = time.perf_counter()
end_time4 = time.process_time()

print(f'1. datetime.now() 运行时间是:{end_time1-start_time1}')
print(f'2. time.time() 运行时间是:{end_time2-start_time2}秒')
print(f'3. time.perf_counter() 运行时间是:{end_time3-start_time3}秒')
print(f'4. time.process_time() 运行时间是:{end_time4-start_time4}秒')
# print(f'5. timeit 运行时间是:{t}秒')

相关推荐

打印机如何网络共享打印(打印机网络共享打印怎么设置)

想要建立打印机共享使用的方法如下1右击【计算机】选择【管理】,在弹出的【计算机管理】窗口中:系统工具->本地用户和组->用户,在右边找到【Guest】双击进去,把账户已禁用的勾选去掉。2回...

电脑开机蓝屏怎么修复0x0000007b
  • 电脑开机蓝屏怎么修复0x0000007b
  • 电脑开机蓝屏怎么修复0x0000007b
  • 电脑开机蓝屏怎么修复0x0000007b
  • 电脑开机蓝屏怎么修复0x0000007b
联想售后维修服务地址(联想售后维修 电话)

官方网站:http://www.lenovo.com.cn/作为全球电脑市场的领导企业,联想从事开发、制造并销售可靠的、安全易用的技术产品及优质专业的服务,帮助全球客户和合作伙伴取得成功。联想公司主要...

华硕系统(华硕系统恢复)

华硕电脑安装的是微软公司的windows系统。一般的华硕电脑出厂的时候安装的都是微软的操作系统,不会安装安卓或者苹果的操作系统。安卓的操作系统一般都是安装在手机上面的,苹果的操作系统都是安装在苹果手机...

wifi强力破解软件排名(wife强力破解软件)

目前我还沒发现有可以破解WiFi密码的软件,有可能有,但这是违法的,所以开发者不可能在网上发布的。有很多人说万能钥匙,其实万能钥匙不是破解WiFi密码,而是密码共享,也就是说一台手机上安装万能钥匙,有...

电脑回收站怎么找出来(电脑回收站到哪里找)

1、打开电脑来到桌面,在空白的地方单击右键,在跳出来的属性中选择个性化。2、点击更改桌面图片,然后会跳出一个桌面图标设置,对桌面上固有图标的更改。3、在桌面图标设置中你可以看到回收站前面未勾选,勾选了...

windows xp电脑公司特别版(正版windows xp)

1、请看下你的游戏说明,是否需要最新版本的显卡驱动支持,如果需要,请将你的显卡驱动升级到最新版。另外,Win7系统内置了很多显卡驱动程序,所以很多计算机在安装完操作系统后都不需要再安装显卡驱动,但是还...

win7怎么设置定时关机命令(windows7设置定时关机)

1、点击屏幕左下方的开始菜单,点运行,输入cmd,  2、弹出一个黑色的框,在里面输入shutdown-f-s-t3600,记住后面这几个字母要加空格,这里面的3600代表的是3600秒,比如...

windows7恢复出厂设置后账户停用

1、重新开机或电脑重启的过程中,也就是在出现品牌Logo的时候,连续按F8进入安全模式,选择带命令行的安全模式。 2、管理员身份打开的命令提示符窗口,输入并回车执行:compmgmt.msc命令。3...

随身wifi每月怎么交钱(随身wifi是怎么交费的)

需要看具体的随身wifi服务商和套餐类型。一般来说,续费可以通过以下途径实现:1.网上续费:登录随身wifi服务商的官网,找到相应的续费渠道,选择套餐并支付即可;2.APP续费:下载随身wifi...

共享打印机需要输入用户名和密码

  WindowsXP一直提示凭证不足,输入Guest用户名或者什么名都试过,密码为空,还是提示凭证不足。不过解决了,顺便分享下方法。  以下是在打印机主机的设置:  在Win10电脑中,...

360文件恢复工具下载(360的文件恢复功能怎么样)

文件恢复工具是在360安全卫士里的一个组件360文件恢复,可以帮助您快速从硬盘,U盘,SD卡等磁盘设备中恢复,被误删的文件360安全卫士的文件恢复功能在360的工具里。操作办法如下:1、打开360安全...

1660s现在全是矿卡了吧(1660有矿卡)

是的。1660super显卡已经停产了,1660super有着高算力低功耗的特点,他是最受矿工欢迎的显卡,市场上在卖的不是矿卡未翻新就是矿卡翻新。16系的显卡都因为有图灵架构所以架构特别高,这个架构带...

office2016激活软件(office2016激活工具免费下载)
  • office2016激活软件(office2016激活工具免费下载)
  • office2016激活软件(office2016激活工具免费下载)
  • office2016激活软件(office2016激活工具免费下载)
  • office2016激活软件(office2016激活工具免费下载)
腾讯电脑管家软件中心介绍(腾讯电脑管家官网是多少)

可以加速升级qq等级,还有就是清除电脑病毒基本靠谱,现在完全靠谱的软件太少了,功能好一点,就乌七八糟全是广告,也可以理解,都要挣钱的嘛。QQ电脑管家这点就比较好,性能好用,一贯的清爽没广告,大公司的...

取消回复欢迎 发表评论: