Python计算程序运行时间的六种方法
off999 2024-09-13 13:30 52 浏览 0 评论
- 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- time.time() 方法
- 返回自纪元以来的秒数作为浮点数,但是时期的具体日期和闰秒的处理取决于使用的平台。比如:在Windows和大多数Unix系统上,纪元是1970年1月1日00:00:00(UTC),并且闰秒不计入自纪元以来的秒数,这也通常被称为Unix时间。
- 时间总是作为浮点数返回,但并非所有系统都提供高于1秒的精度。
- 使用 time_ns() 以避免 float 类型导致的精度损失。
- time.perf_counter() 方法
(以小数表示的秒为单位)返回一个性能计数器的值,即用于测量较短持续时间的具有最高有效精度的时钟。 它会包括睡眠状态所消耗的时间并且作用于全系统范围。 两次调用之间的差值才是有效的。
- time.process_time() 方法
(以小数表示的秒为单位)返回当前进程的系统和用户 CPU 时间的总计值。 它不包括睡眠状态所消耗的时间。 根据定义它只作用于进程范围。
- 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()))- %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}秒')相关推荐
- 台式电脑线路安装步骤图(台式电脑怎么安装线路图)
-
安装电脑线路需要以下步骤:首先,确定电脑所需的线路类型,如电源线、网线等。然后,将线路插头与相应的接口连接,确保插头与接口对应正确。接下来,将线路沿着合适的路径布置,避免过度弯曲或拉扯。在布置线路时,...
- qq空间触屏版登录入口(qq空间登录入口首页)
-
z.qq.com可以通过以下方式登录手机QQ空间:1、使用手机登录手机腾讯网3g.qq.com,点击“空间”,根据提示QQ号码和QQ密码就可以登录;2、通过手机直接输入手机QQ空间网址z.qq.co...
- 笔记本电脑开机密码怎么关闭
-
1、用户账户密码取消 取消用户账户密码的方法比较简单,在“控制面板”中的“用户账户”中,选择你要修改的账户,然后点“删除我的密码”的选项,选择“删除密码”即可,也可以在选择更改密码时,把新密码留空,...
- 鼠标usb设备无法识别(鼠标usb设备无法识别win10)
-
1.前置USB线接错。当主板上的USB线和机箱上的前置USB接口对应相接时把正负接反就会发生这类故障,这也是相当危险的,因为正负接反很可能会使得USB设备烧毁。所以尽量采用机箱后置的USB接口,也少...
-
- 腾讯游戏实名认证中心官网(腾讯游戏实名制平台)
-
腾讯游戏实名认证非常的简单,首先,打开腾讯游戏实名注册网址:jkyx.qq.com打开jkyx.qq.com,登陆你的QQ账号,如果你的QQ账号已经实名注册了,该网站就能看到已注册的信息的。如果还未实名注册的玩家,就可以在该网站按照要求填...
-
2025-12-24 19:03 off999
- 电脑城照片(电脑照的相片在哪里找)
-
开平的电脑城在市府文化广场旁边那条桥的桥头(光明路),美媛电脑城,不过好像很破烂,此外曙光路很多电脑店。有三家电子/电脑城,其中最大两家在107国道沙井上南加油站路段两旁,那里有很多电子零件和电脑...
- kali linux安装教程(kali linux最新版安装教程)
-
KaliLinux官方正确安装方法为先从官网下载最新版本的ISO镜像文件,然后使用软件如Rufus将ISO文件写入U盘或DVD,接着在计算机启动时选择U盘或DVD作为启动设备,进入KaliLinu...
- asus电脑开不了机怎么办(华硕电脑开不机怎么办)
-
1、检查电源和电源适配器如果华硕笔记本无法开机,首先要排查电源和电源适配器是否正常工作。可以检查电源适配器是否插紧,是否有松动或断裂。另外,可以更换电源适配器或更换电池,看是否可以开机。2、检查硬件连...
- bios硬盘启动项是哪个(电脑bios硬盘启动)
-
1、开机按F2(具体按键看开机屏幕提示)进入BIOS系统,打开Boot选项卡;2、在Boot页面下找到IDE1,一般这个表示的就是电脑硬盘,按键盘上的F6将该启动项向上移至第一位,也就是将硬盘设为第一...
- 虚拟机ubuntu安装教程(ubuntu 虚拟机安装)
-
在虚拟机Ubuntu下安装MATLAB的步骤如下:1.下载MATLAB安装包:访问MATLAB官网,选择适合你的Ubuntu版本的MATLAB安装包,并下载到本地计算机。2.安装虚拟机软件:在Ub...
- bootmgrismissing开机不了怎么办
-
你是不是没打全?大概意思就是启动的东西缺失!重装系统或者是补充装修复系统引导bootmgr丢失无法开机的解决方法:1、重新启动计算机,如果遇到“BOOTMGRismissing”错误,可以尝试的第...
- 手机上怎么改路由器密码(手机上怎么改路由器密码wifi密码)
-
输入地址打开手机浏览器后在地址栏输入路由器地址,打开路由器登录界面。2/4点击常用设置输入路由器管理员密码后进入路由器主界面,点击上方的常用设置。3/4找到密码在窗口中分别找到2.4G和5Gwifi...
- windowsserver2016(windowsserver2016激活密钥)
-
WindowsServer2016代表着微软发布的一款服务器操作系统。它是2016年推出的,为企业提供了强大的功能和稳定性,支持大规模的数据中心和云计算环境。WindowsServer2016...
- 联想手机官网查询真伪入口(联想手机正品查询)
-
官方查询页面http://support1.lenovo.com.cn/lenovo/wsi/我认为联想本本一旦出厂就自然就可以查询号码了。因为我们单位订购的一批联想本本,直接从上海生产基地把本本...
- 中国电信官方测网速(网络测速 中国电信)
-
你好,你可以下载一个第三方软件进行测速,如果你手机自带测速软件直接可以测速的,也可以下载电信测速软件。1.进入中国电信官方测速网站。 说明:中国电信宽带测速是根据网络行业网速标准制定的专业测速工具,...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
