Python 使用with上下文实现计时功能
引言
with语句是从Python2.5开始引入的一种与异常处理相关的功能(2.5版本中要通过from__future__importwith_statement导入后才可以使用),从2.6版本开始缺省可用(参考What'snewinPython2.6?中with语句相关部分介绍)。with语句适用于对资源进行访问的场合,确保不管使用过程中是否发生异常都会执行必要的“清理”操作,释放资源,比如文件使用后自动关闭、线程中锁的自动获取和释放等。
在Python常常需要记录一段代码运行了多长时间,普通的一般用两个time.time(),然后计算差值;高级一点的,就是写一个计时装饰器,用装饰器包裹方法,记录运行时间,但这这意味着你的代码需要写在函数里,然后才能使用此计时装饰器。
今天我要介绍的是一种可以给一段代码计时,而不是一个函数计时的方便的、“高级的”的Python计时方法。
代码如下:
fromcontextlibimportcontextmanager @contextmanager deftimer(name): start=time.time() yield print(f'[{name}]donein{time.time()-start:.2f}s')
使用方法:
withtimer('Test'): i=0 whilei<1000000: i+=1
输出:
[Test]donein0.11s
从1加到1百万需要0.11s。可以在timer通过修改.2f来修改时间精度。
总结
以上所述是小编给大家介绍的Python使用with上下文实现计时功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!