为了账号安全,请及时绑定邮箱和手机立即绑定

Python进阶-高级语法

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.联系:生成器对象就是一种可迭代对象,可以被迭代器遍历。

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

图片描述

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消