Python while、for、生成器、列表推导等语句的执行效率测试


Posted in Python onJune 03, 2015

一个功能的实现,可以用多种语句来实现,比如说:while语句、for语句、生成器、列表推导、内置函数等实现,然而他们的效率并不一样。写了一个小程序来测试它们执行的效率。

测试内容:
将一个数字大小为20万的数字,依次取绝对值,放到列表中,测试重复1千次.
测试程序:

import time,sys  

reps = 1000                #测试重复次数  

nums = 200000              #测试时数字大小  

  

  

def tester(func,*args):    #总体测试函数  

    startTime = time.time()  

    for i in range(reps):  

        func(*args)  

    elapsed = time.time() - startTime #用time模块来测试,结束时间与开始时间差  

    return elapsed  

  

def while_Statement():     #while循环实现  

    res = []  

    x   = 0  

    while nums > x:  

        x += 1  

        res.append(abs(x))  

  

def for_Statement():       #for循环实现  

    res = []  

    for x in range(nums):  

        res.append(abs(x))  

  

def generator_Expression():#生成器实现  

    res = list(abs(x) for x in range(nums))  

  

def list_Comprehension():  #列表解析实现  

    res = [abs(x) for x in range(nums)]  

  

  

def map_Function():        #内置函数map实现  

    res = map(abs, range(nums))  

  

  

print sys.version          #打印系统版本  

tests = [while_Statement, for_Statement, generator_Expression, list_Comprehension, map_Function]  

for testfunc in tests:     #将待测函数放置列表中依次遍历  

    print testfunc.__name__.ljust(20),': ',tester(testfunc)  #  

 

测试结果:

>>>   

2.7.4 (default, Apr  6 2013, 19:55:15) [MSC v.1500 64 bit (AMD64)]  

while_Statement      :  84.5769999027  

for_Statement        :  75.2709999084  

generator_Expression :  62.3519999981  

list_Comprehension   :  60.4090001583  

map_Function         :  47.5629999638 

改写程序:
import sys  

nums = 100  

  

def while_Statement():  

    res = []  

    x   = 0  

    while nums > x:  

        x += 1  

        res.append(abs(x))  

  

def for_Statement():  

    res = []  

    for x in range(nums):  

        res.append(abs(x))  

  

def generator_Expression():  

    res = list(abs(x) for x in range(nums))  

  

def list_Comprehension():  

    res = [abs(x) for x in range(nums)]  

  

  

def map_Function():  

    res = map(abs, range(nums))  

  

if __name__=='__main__':  

    import timeit            #用timeit模块来测试  

    print sys.version  

    funcs = [while_Statement, for_Statement, generator_Expression, list_Comprehension, map_Function]  

    for func in funcs:  

        print func.__name__.ljust(20),': ',timeit.timeit("func()", setup="from __main__ import func") 

测试结果:

>>>   

2.7.4 (default, Apr  6 2013, 19:55:15) [MSC v.1500 64 bit (AMD64)]  

while_Statement      :  37.1800067428  

for_Statement        :  30.3999109329  

generator_Expression :  27.2597866441  

list_Comprehension   :  17.386223449  

map_Function         :  12.7386868963 

测试分析:

用time模块,和timeit模块两种测试方式测试了很多组数字,得出的结果是执行内置函数最快,其次就是列表推导,再其次生成器和for循环,while循环最慢。一般最快的使用内置函数的方法要比使用最慢的while快两倍以上。简单分析下原因:内置函数比如说map,filter,reduce(在Python3.0中移除)基本上都是用C语言来实现的,所以速度是最快的,列表推导内的迭代在解释器内是以C语言的速度运行的(一般是for循环的两倍,对大型文件操作而言,用列表推导效果尤其明显),相比较for循环代码是在PVM步进运行要快的多。但for循环里面含range(),相对速度也会快些,while语句是纯粹用Python代码写成,所以速度最慢。所以函数式编程最好使用内置函数,然后才考虑使用列表推导或for循环。最好不用while循环.

Python 相关文章推荐
跟老齐学Python之深入变量和引用对象
Sep 24 Python
Python进阶_关于命名空间与作用域(详解)
May 29 Python
Python复数属性和方法运算操作示例
Jul 21 Python
Python简单生成随机数的方法示例
Mar 31 Python
python实现最长公共子序列
May 22 Python
python指定写入文件时的编码格式方法
Jun 07 Python
[原创]Python入门教程4. 元组基本操作
Oct 31 Python
python实现kNN算法识别手写体数字的示例代码
Aug 16 Python
Python3 合并二叉树的实现
Sep 30 Python
python实现的汉诺塔算法示例
Oct 23 Python
python读取excel进行遍历/xlrd模块操作
Jul 12 Python
Django数据统计功能count()的使用
Nov 30 Python
Python fileinput模块使用实例
Jun 03 #Python
以windows service方式运行Python程序的方法
Jun 03 #Python
自己编程中遇到的Python错误和解决方法汇总整理
Jun 03 #Python
python中list常用操作实例详解
Jun 03 #Python
python中argparse模块用法实例详解
Jun 03 #Python
Python中的推导式使用详解
Jun 03 #Python
对于Python装饰器使用的一些建议
Jun 03 #Python
You might like
理解和运用PHP中的多态性[译]
2011/08/02 PHP
ajax完美实现两个网页 分页功能的实例代码
2013/04/16 PHP
ThinkPHP中URL路径访问与模块控制器之间的关系
2014/08/23 PHP
PHP基于工厂模式实现的计算器实例
2015/07/16 PHP
JavaScript 快捷键设置实现代码
2009/03/13 Javascript
修改好的jquery滚动字幕效果实现代码
2011/06/22 Javascript
js工具方法弹出蒙版
2013/05/08 Javascript
window.onerror()的用法与实例分析
2016/01/27 Javascript
利用jQuery插件imgAreaSelect实现图片上传裁剪(同步显示图像位置信息)
2016/12/02 Javascript
详解Angualr 组件间通信
2017/01/21 Javascript
vue2.0 中#$emit,$on的使用详解
2017/06/07 Javascript
在页面中引入js的两种方法(推荐)
2017/08/29 Javascript
基于JSONP原理解析(推荐)
2017/12/04 Javascript
vue.js整合mint-ui里的轮播图实例代码
2017/12/27 Javascript
react组件基本用法示例小结
2020/04/27 Javascript
Element Steps步骤条的使用方法
2020/07/26 Javascript
JQuery+drag.js上传图片并且实现图片拖曳
2020/11/18 jQuery
python实现的解析crontab配置文件代码
2014/06/30 Python
python中的常量和变量代码详解
2018/07/25 Python
python中wx模块的具体使用方法
2020/05/15 Python
matplotlib更改窗口图标的方法示例
2021/02/03 Python
预订奥兰多和佛罗里达州公园门票:FloridaTix
2018/01/03 全球购物
常见的软件开发流程有哪些
2015/11/14 面试题
Ajax主要包含了哪些技术
2014/06/12 面试题
水污染治理专业毕业生推荐信
2013/11/14 职场文书
财务会计实习报告体会
2013/12/20 职场文书
超市开业庆典策划方案
2014/05/14 职场文书
师范大学生求职信
2014/06/13 职场文书
乡文化站暑期培训方案
2014/08/28 职场文书
领导班子四风查摆对照检查材料思想汇报
2014/10/05 职场文书
群众路线学习笔记范文
2014/11/06 职场文书
2014年协会工作总结
2014/11/22 职场文书
数学教师个人工作总结
2015/02/06 职场文书
css背景和边框标签实例详解
2021/05/21 HTML / CSS
Win11局域网共享权限在哪里设置? Win11高级共享的设置技巧
2022/04/05 数码科技
Windows 64位 安装 mysql 8.0.28 图文教程
2022/04/19 MySQL