[Python] python中的代码运行时间获取方式

2050 0
王子 2022-11-6 09:58:27 | 显示全部楼层 |阅读模式
目录

    第一种第二种第三种第四种

我们知道为了提高代码的运行速度,我们需要对书写的python代码进行性能测试,而代码性能的高低的直接反馈是电脑运行代码所需要的时间。
这里将介绍四种常用的测试代码运行速度的方法。

第一种

使用time模块对代码的运行时间进行统计,代码如下:
  1. import time
  2. class Debug:
  3.   def mainProgram(self):
  4.     start_time = time.time()
  5.     for i in range(100):
  6.       print(i)
  7.     end_time = time.time()
  8.     print(f"the running time is: {end_time - start_time} s")
  9. if __name__ == "__main__":
  10.   main = Debug()
  11.   main.mainProgram()
复制代码
我们采用time 模块给所要测试的代码的前后加上时间戳,一个记为start_time,一个记作end_time,最后代码块的运行时间为end_time-start_time,单位为s(秒)。
当然在python中还有许多的记录时间的模块,这里不做过多讨论,均类似于time模块,实现思路上一致,代码实现上大同小异。

第二种

使用IPython的uilt-in magic commands,%time,代码如下:
  1. class Debug:
  2.   def mainProgram(self):
  3.     %time for i in range(100): print(i)
  4. main = Debug()
  5. main.mainProgram()
  6. """
  7. Wall time: 1.99 ms
  8. """
复制代码
这个类定义是可以去掉的,并不会影响最终的结果,%time 后面加上想要计算时间的代码,然后编译器就会在运行后自动给出所测试代码的运行时间,但是经过测试,%time方法测出的时间并不准确,时间波动范围非常大,这个是很好理解的,因为计算机每时每刻都在处理一些进程,也就是说计算机的运行状态每时每刻都是不同的,所以在不同的时刻测试同一段代码的运行时间也会得到不同的结果。

第三种

用IPython的另一个Built-in magic commands,%timeit,使用方法类似于%time,代码如下:
  1. class Debug:
  2.   def mainProgram(self):
  3.     %timeit for i in range(100): print(i)
  4. main = Debug()
  5. main.mainProgram()
  6. """
  7. 8.53 ms ± 452 s per loop (mean ± std. dev. of 7 runs, 100 loops each)
  8. """
复制代码
我们可以看到得到的结果是:每个循环8.53 ms±452 s(平均±标准偏差,共运行7次,每个循环100个)%timeit相比于%time,%timeit会多次执行测试代码,并且会取它们运行时间的平均值,并且还会计算出它们的标准差,因此这种计算方法计算的结果相对于使用%time执行测试代码一次是比较准确的。

第四种

导入timeit模块来计算代码块的执行时间
  1. import timeit
  2. class Debug:
  3.   def mainProgram(self):
  4.     result = timeit.timeit(stmt="for i in range(100): print(i)", number=10)
  5.     print(result)
  6. main = Debug()
  7. main.mainProgram()
  8. """
  9. 0.05363089999991644 s
  10. """
复制代码
导入timeit模块后使用timeit.timeit()来测试想要测试的代码,并且代码以string的形式进行输入,并且需要设定number值,设定测试的该段代码需要执行的次数,最终我们得到0.05363089999991644,单位是s(秒),与内置魔法方法%timeit方法不同的是虽然也是多次计算,但是最终获取的时间是n次执行代码所需的总时间而不是执行一次的时间。
至此,代码的运行速度测试方法的介绍暂时告一段落。
当然,还有一种进阶操作可以用来测试脚本文件的性能,python 脚本性能分析(超链接点击跳转)。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持中国红客联盟。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

中国红客联盟公众号

联系站长QQ:5520533

admin@chnhonker.com
Copyright © 2001-2025 Discuz Team. Powered by Discuz! X3.5 ( 粤ICP备13060014号 )|天天打卡 本站已运行