博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
什么是列表推导式,生成器,迭代器?
阅读量:5302 次
发布时间:2019-06-14

本文共 3247 字,大约阅读时间需要 10 分钟。

 

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**5tips: 推导式会一次性读取列表内所有数据'''@profiledef 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:'''@profiledef main():    # 生成器    num1 = (x for x in range(10, 10**4))    return num1if __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.联系:生成器对象就是一种可迭代对象,可以被迭代器遍历。

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

格子兮

 

转载于:https://www.cnblogs.com/wqunlong/p/10048881.html

你可能感兴趣的文章
js千分位处理
查看>>
js常用的方法
查看>>
Mac---------三指拖移
查看>>
关于VMare中安装Ubuntu的一些说明
查看>>
七、K3 WISE 开发插件《工业单据老单插件中获取登陆用户名》
查看>>
字符串类型的相互转换
查看>>
图片编辑的利器(介绍韩国免费图片工具PhotoScape)
查看>>
Python基础第十一天:递归函数
查看>>
钉钉机器人
查看>>
博雅PHP高级工程师面试题-自拟
查看>>
SQL SERVER 查看表是否存在
查看>>
关于easyUI实现自定义网格视图
查看>>
JAVA小知识点-Finally和Return的执行关系
查看>>
基站转经纬度
查看>>
构建ASP.NET网站十大必备工具
查看>>
a*寻路分析
查看>>
Android Activity的任务栈和四大启动模式
查看>>
table左边固定-底部横向滚动条-demo
查看>>
MySQL事件异常记录
查看>>
Redis 发布订阅
查看>>