python入门回顾
1.列表是什么?
列表是PYTHON中的一种组合数据类型2.什么时候用?
需要在一个变量中统一整理存储多个可以重复数据的情况下3.为什么要用?
列表可以统一管理多个数据4.如何使用?
声明 数据处理:增删改查[遍历] insert/append/extend pop/remove/cleartips: 列表的使用缺陷:列表中直接存储数据,但是如果列表中的数据较多的话,可能会比较消耗内存【列表数据项较多、内存消耗较多】
针对列表的使用缺陷特征,我们可能会有以下疑问。
问题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.联系:生成器对象就是一种可迭代对象,可以被迭代器遍历。
水平有限,特附小图一张,不当之处,还望包涵!