Python中最快的循环姿势实例详解

作者:somenzz 时间:2022-12-16 01:30:50 

目录
  • 各种姿势

  • 比较快的姿势

  • 最后

各种姿势

比如说有一个简单的任务,就是从 1 累加到 1 亿,我们至少可以有 7 种方法来实现,列举如下:

1、while 循环


def while_loop(n=100_000_000):
   i = 0
   s = 0
   while i < n:
       s += i
       i += 1
   return s

2、for 循环


def for_loop(n=100_000_000):
   s = 0
   for i in range(n):
       s += i
   return s

3、sum range


def sum_range(n=100_000_000):
   return sum(range(n))

4、sum generator(生成器)


def sum_generator(n=100_000_000):
   return sum(i for i in range(n))

5、sum list comprehension(列表推导式)


def sum_list_comp(n=100_000_000):
   return sum([i for i in range(n)])

6、sum numpy


import numpy
def sum_numpy(n=100_000_000):
   return numpy.sum(numpy.arange(n, dtype=numpy.int64))

7、sum numpy python range


import numpy
def sum_numpy_python_range(n=100_000_000):
   return numpy.sum(range(n))

上述 7 种方法得到的结果是一样的,但是消耗的时间却各不相同,你可以猜测一下哪一个方法最快,然后看下面代码的执行结果:


import timeit

def main():
   l_align = 25
   print(f'{"1、while 循环":<{l_align}} {timeit.timeit(while_loop, number=1):.6f}')
   print(f"{'2、for 循环':<{l_align}}  {timeit.timeit(for_loop, number=1):.6f}")
   print(f'{"3、sum range":<{l_align}} {timeit.timeit(sum_range, number=1):.6f}')
   print(f'{"4、sum generator":<{l_align}} {timeit.timeit(sum_generator, number=1):.6f}')
   print(f'{"5、sum list comprehension":<{l_align}} {timeit.timeit(sum_list_comp, number=1):.6f}')
   print(f'{"6、sum numpy":<{l_align}} {timeit.timeit(sum_numpy, number=1):.6f}')
   print(f'{"7、sum numpy python range":<{l_align}} {timeit.timeit(sum_numpy_python_range, number=1):.6f}')

if __name__ == '__main__':
   main()

执行结果如下所示:

Python中最快的循环姿势实例详解

比较快的姿势

for 比 while 块

for 和 while 本质上在做相同的事情,但是 while 是纯 Python 代码,而 for 是调用了 C 扩展来对变量进行递增和边界检查,我们知道 CPython 解释器就是 C 语言编写的,Python 代码要比 C 代码慢,而 for 循环代表 C,while 循环代表 Python,因此 for 比 while 快。

numpy 内置的 sum 要比 Python 的 sum 快

numpy 主要是用 C 编写的,相同的功能,肯定是 numpy 的快,类似的,numpy 的 arange 肯定比 Python 的 range 快。

交叉使用会更慢

numpy 的 sum 与 Python 的 range 结合使用,结果耗时最长,见方法 7。最好是都使用 numpy 包来完成任务,像方法 6。

生成器比列表推导式更快

生成器是惰性的,不会一下子生成 1 亿个数字,而列表推导式会一下子申请全部的数字,内存占有较高不说,还不能有效地利用缓存,因此性能稍差。

最后

本文分享了几种遍历求和的方法,对比了它们的性能,给出了相应的结论

来源:https://blog.csdn.net/somenzz/article/details/121026478

标签:python,循环,while
0
投稿

猜你喜欢

  • Python函数中的全局变量详解

    2022-08-05 13:58:34
  • sql not in 与not exists使用中的细微差别

    2024-01-26 09:40:43
  • 2008年10佳改版网站

    2008-09-22 20:15:00
  • 使用Flask和Django中解决跨域请求问题

    2023-01-16 10:03:10
  • caffe的python接口生成配置文件学习

    2023-07-09 04:46:41
  • Python 多个图同时在不同窗口显示的实现方法

    2022-07-02 01:20:35
  • JSON 和 JavaScript eval使用说明

    2024-04-19 10:00:07
  • 上传图片js判断图片尺寸和格式兼容IE

    2024-04-10 10:48:37
  • python标识符的用法及注意事项

    2023-05-02 03:03:04
  • Google首页的CSS Sprite

    2007-09-29 21:36:00
  • ASP把长的数字用格式化为货币样式的函数

    2009-09-18 14:49:00
  • 获取python文件扩展名和文件名方法

    2023-06-24 16:51:24
  • MySQL查询全部数据集结果不一致问题解决方案

    2024-01-21 23:51:20
  • go单体日志采集zincsearch方案实现

    2024-04-23 09:43:13
  • css基础教程布局篇之一

    2008-07-31 17:21:00
  • 利用Pycharm断点调试Python程序的方法

    2023-07-05 03:47:08
  • 用asp获取微软安全更新列表的代码 小偷程序

    2011-02-24 11:19:00
  • Python 读取位于包中的数据文件

    2023-06-09 00:16:03
  • Oracle批量查询、删除、更新使用BULK COLLECT提高效率

    2023-07-14 03:15:52
  • 浅谈pytorch 模型 .pt, .pth, .pkl的区别及模型保存方式

    2023-11-25 12:41:38
  • asp之家 网络编程 m.aspxhome.com