Python 使用with上下文实现计时功能
引言
with 语句是从 Python 2.5 开始引入的一种与异常处理相关的功能(2.5 版本中要通过 from __future__ import with_statement 导入后才可以使用),从 2.6 版本开始缺省可用(参考 What's new in Python 2.6? 中 with 语句相关部分介绍)。with 语句适用于对资源进行访问的场合,确保不管使用过程中是否发生异常都会执行必要的“清理”操作,释放资源,比如文件使用后自动关闭、线程中锁的自动获取和释放等。
在Python常常需要记录一段代码运行了多长时间,普通的一般用两个 time.time()
,然后计算差值;高级一点的,就是写一个计时装饰器,用装饰器包裹方法,记录运行时间,但这这意味着你的代码需要写在函数里,然后才能使用此计时装饰器。
今天我要介绍的是一种可以给一段代码计时,而不是一个函数计时的方便的、“高级的”的Python计时方法。
代码如下:
from contextlib import contextmanager @contextmanager def timer(name): start = time.time() yield print(f'[{name}] done in {time.time() - start:.2f} s')
使用方法:
with timer('Test'): i = 0 while i < 1000000: i += 1
输出:
[Test] done in 0.11 s
从1加到1百万需要0.11s。可以在 timer 通过修改 .2f 来修改时间精度。
总结
以上所述是小编给大家介绍的Python 使用with上下文实现计时功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
- 深入解析Python中的上下文管理器
- Python深入学习之上下文管理器
- Python标准模块--ContextManager上下文管理器的具体用法
- Python中的with语句与上下文管理器学习总结
- 正确理解python中的关键字“with”与上下文管理器
- Python with语句上下文管理器两种实现方法分析
- 深入学习Python中的上下文管理器与else块
- Python with关键字,上下文管理器,@contextmanager文件操作示例
- 详解Python中contextlib上下文管理模块的用法
- Python中的上下文管理器和with语句的使用
- Python上下文管理器类和上下文管理器装饰器contextmanager用法实例分析
相关文章
Python ORM框架SQLAlchemy学习笔记之关系映射实例
这篇文章主要介绍了Python ORM框架SQLAlchemy学习笔记之关系映射实例,Classic (经典模式)和Modern (现代模式),分别介绍了,需要的朋友可以参考下2014-06-06使用tensorflow根据输入更改tensor shape
这篇文章主要介绍了使用tensorflow根据输入更改tensor shape,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-06-06CentOS 7下安装Python 3.5并与Python2.7兼容并存详解
这篇文章主要给大家介绍了在CentOS 7下安装Python 3.5并与Python2.7兼容并存的相关资料,文中将安装步骤介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面跟着小编来一起学习学习吧。2017-07-07python中时间转换datetime和pd.to_datetime详析
这篇文章主要给大家介绍了关于python中时间转换datetime和pd.to_datetime的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用python具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧2019-08-08matplotlib交互式数据光标mpldatacursor的实现
这篇文章主要介绍了matplotlib交互式数据光标mpldatacursor的实现 ,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2021-02-02
最新评论