对比了Python3的五种迭代方式进行函数简单计算的花费时间
五种迭代分别是,for循环,列表推导式,内置函数map(),生成器推导式,生成器函数
简单计算以add()加10操作和abs()绝对值举例

运行次数指每个函数执行的次数,默认每个函数对10000个数进行计算。

从测试结果可以看出效率从高到低依次为:

调用map > 列表解析 > 生成器函数 > 生成器表达式 > for循环

python 循环函数 python循环函数迭代次数_for循环

import time
import sys
#函数重复次数


def timer(func,*pargs,**kargs):
# func函数名称,后面两个是参数
    start = time.clock()
    # 开始时间
    for i in range(runtime):
        ret = func(*pargs,**kargs)
    elapsed = time.clock() - start
    # 花费时间
    return (elapsed,ret)
    # ret记录最后一次结果


reps=10000
repslist=range(reps)


def forloop():
    res = []
    for x in repslist:
        res.append(abs(x))
    return res
#通过for循环迭代

def listComp():
    return [abs(x) for x in repslist]
#列表解析

def mapCall():
    return list(map(abs,repslist))
#调用map

def genExpr():
    return list(abs(x) for x in repslist)
#生成器表达式

def genFunc():
    def gen():
        for x in repslist:
            yield abs(x)
    return list(gen())
#生成器函数


# ======================================================================
def add(k):
    return k+10

def forloop2():
    res = []
    for x in repslist:
        res.append(add(x))
    return res
#通过for循环迭代

def listComp2():
    return [add(x) for x in repslist]
#列表解析

def mapCall2():
    return list(map(add,repslist))
#调用map

def genExpr2():
    return list(add(x) for x in repslist)
#生成器表达式

def genFunc2():
    def gen():
        for x in repslist:
            yield add(x)
    return list(gen())
#生成器函数


runtime=int(input('输入运行次数:'))
print(sys.version)
for test in (forloop,listComp,mapCall,genExpr,genFunc):
    elapsed, result = timer(test)
    print ('{0:10}: {1:.5f} => [{2:}...{3:}]'.format(test.__name__,elapsed,result[0],result[-1]))
print ('-'*40)
for test in (forloop2,listComp2,mapCall2,genExpr2,genFunc2):
    elapsed, result = timer(test)
    print ('{0:10}: {1:.5f} => [{2:}...{3:}]'.format(test.__name__,elapsed,result[0],result[-1]))