zoukankan      html  css  js  c++  java
  • Python五种迭代方式 for循环,列表推导式,内置函数map(),生成器推导式,生成器函数 速度对比

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

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

    从测试结果可以看出效率从高到低依次为:
    调用map > 列表解析 > 生成器函数 > 生成器表达式 > 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]))
    
  • 相关阅读:
    梯度下降算法实现
    windows10下Anaconda的安装与tensorflow、opencv的安装与环境配置
    在github创建用户
    看完教材不明白的问题
    自我介绍
    HDU 1098(条件满足 数学)
    HDU 1097(m次幂的个位数 规律)
    HDU 1046(最短路径 **)
    HDU 1045(炮台安置 DFS)
    HDU 1034(传递糖果 模拟)
  • 原文地址:https://www.cnblogs.com/kuronekonano/p/11135687.html
Copyright © 2011-2022 走看看