• 什么是列表推导式,生成器,迭代器?


    python入门回顾

    1.列表是什么?
      列表是PYTHON中的一种组合数据类型 

    2.什么时候用?
      需要在一个变量中统一整理存储多个可以重复数据的情况下

    3.为什么要用
      列表可以统一管理多个数据

    4.如何使用?
      声明 数据处理:增删改查[遍历]
      insert/append/extend
      pop/remove/clear

    tips:
    列表的使用缺陷:列表中直接存储数据,但是如果列表中的数据较多的话,可能会比较消耗内存【列表数据项较多、内存消耗较多】

    针对列表的使用缺陷特征,我们可能会有以下疑问。
    问题1:列表数据较多?怎么添加?
    问题2:列表数据消耗内存较多?怎么优化?

    接下来我们来通过三个名词来探寻解决问题之道。


    1.列表推导式

    一般情况下,如果一个列表中要存储大量相关数据,这些数据通常都是有规律的。
    [如果列表中存储的数据量并不是很大,数据之间的关联关系可能并不是很大]
    [如果列表中存储的数据量非常大,数据之间的关联关系非常强]

    列表中的数据如果一旦存在指定的规律[简单->复杂],  
    通过指定的规则就可以自动推到存储列表对象,列表中的数据可以直接产生——列表推导式
    

    列表推导式:程序表达式:可以运算的程序代码

    基本推导式:得到一个0~100的自然数序列列表

    • 手工创建添加数据
      纯手工输入,不推荐。

    • 循环语法添加[可读性较高,代码较多]

    # 常规方式
    nums2 = list()
    for i in range(0, 100):
        nums.append(i)
    print(nums)
    
    打印结果为:[0, 1, 2, 3, … ,100]
    • 推导式操作
    nums3 = [x for x in range(0, 100)]
    print(nums)
    
    打印结果为:[0, 1, 2, 3, … ,100]

    eg:
    有一个班级的学生的成绩,求所有大于平均成绩的成绩名单。
    *

    # 常规操作
    score = [20, 50, 69, 70, 99, 145, 149]
    average1 = sum(score)/len(score)
    score1 = list()
    for s in score:
        if s >= avg:
        score1.append(s)
    print(score1)
    
    打印结果为:[99, 145, 149]
    # 列表推导式简化
    score = [20, 50, 69, 70, 99, 145, 149]
    score2 = [s for s in score if s >= sum(score)/len(score)]
    print(score2)
    
    打印结果为:[99, 145, 149]

    列表推导式通过表达式定义的规则,可以在一个表达式中给列表增加指定规则的元素

    2.列表生成器

    生成器:在使用过程中,根据指定的规则运算产生列表元素数据
    使用过程:运行时
    运算产生:规则 == 推导式

    生成器和推导式区别:
         推导式: 使用列表的运行前 得到完整列表
         生成器: 使用列表 运行时 得到下一个列表元素

    生成器:推导式->将推导式的语法方括号->修改成圆括号
      推导式->列表[list]->包含具体元素数据->索引/下标-获取数据
          数据量较大:运算消耗时间消耗内存
      生成器->对象[generator]->包含运算规则->next()
          /next()-获取数据与数据量大小无关

    from memory_profiler import profile
    '''
    使用推导式计算数据量大的数如:10**5
    tips: 推导式会一次性读取列表内所有数据
    '''
    
    @profile
    def main():
        # 推导式
        num1 = [x for x in range(10, 10**5)]
        return num1
        
    if __name__ == "__main__":
        num1 = main()
    
    

    打印结果为:一般电脑(4-6G内存)会出现卡顿,表明此时计算机计算的数据过大
    小编的笔记本电脑为6G内存,证实有出现了卡顿现象。如配置较低,可将5改为4或者3即可。

    Line #    Mem usage    Increment   Line Contents
    ================================================
         4     16.3 MiB     16.3 MiB   @profile
         5                             def main():
         6                                 # 推导式
         7     16.7 MiB      0.4 MiB       num1 = [x for x in range(10, 10**4)]
         8     16.7 MiB      0.0 MiB       return num1
    

    
    from memory_profiler import profile
    '''
    列表生成器(优化内存分配)
    tips:
    '''
    
    @profile
    def main():
        # 生成器
        num1 = (x for x in range(10, 10**4))
        return num1
    
    
    if __name__ == "__main__":
        num1 = main()
        print(type(num1))
    

    打印结果为:

    Line #    Mem usage    Increment   Line Contents
    ================================================
         4     16.3 MiB     16.3 MiB   @profile
         5                             def main():
         6                                 # # 推导式
         7                                 # num1 = [x for x in range(10, 10**4)]
         8                                 # return num1
         9                                 # 生成器
        10     16.3 MiB      0.0 MiB       num1 = (x for x in range(10, 10**4))
        11     16.3 MiB      0.0 MiB       return num1
    
    

    生成器的使用注意事项:
      1.如果是项目中的对象数据使用,要存储到列表中->跟生成器/推导式 无关
          列表->作用:只是一个临时存储多个数据的小容器
      2.项目中定义固定规则的数据列表用来参与业务运算:生成器/推导式
          项目开发中,定义验证码字符
      3.项目中的核心算法使用到大量有规则的数据:生成器
          核心模块中开发数据算法:生成器-技术层面的数学算法开发
          核心模块中的算法改造:生成器- 技术+业务 完成的算法修改

    3.迭代器

    列表、推导式、生成器 -> 都是通过 for循环遍历完成数据处理的

    简述生成器和迭代器的区别与联系?

    1.生成器主要是定义了一个数据的生成规则,通过运行时算法得到类似列表数据的一种特殊对象

    2.迭代器是用于循环遍历可迭代数据的一个特殊对象,包含了迭代对象和迭代过程

    3.联系:生成器对象就是一种可迭代对象,可以被迭代器遍历。

    水平有限,特附小图一张,不当之处,还望包涵!

    格子兮

  • 相关阅读:
    百度文库文档下载分析
    旅游公司招聘Java工程师
    C# 在Repeater 的ItemDataBound 如何转换e.Item.DataItem 的类型
    IOS多线程GCD
    vDSP加速的应用
    ios获取内核数目
    Struts06---通配符的使用
    Struts05---动态查询
    Struts04---命名空间的查询顺序以及默认执行的Action
    Struts03---参数传递
  • 原文地址:https://www.cnblogs.com/wqunlong/p/10048881.html
Copyright © 2020-2023  润新知