当前位置: 首页 > news >正文

Python生成器(python系列25)

前言:什么是生成器,他和迭代器的区别是什么?什么时生成器表达式,为什么和列表推导式那么像呢?

生成器:

定义:能够动态(循环一次,计算一次,返回一次)提供数据的可迭代对象。

作用:在循环过程中,按照某种算法推算数据,不必创建容器存储完整的结果,从而节省内存空间。延迟操作或者惰性操作,在需要的时候计算结果,而不是一次构建所有结果。

生成器原理代码案例:

"""生成器原理"""
class MyGenerator:def __init__(self):self.list_generator = []self.index = -1def __iter__(self):return selfdef __next__(self):try:self.index += 1return self.list_generator[self.index]except IndexError:raise StopIterationmy_generator = MyGenerator()
my_generator.list_generator = [1, 2, 3, 4, 5, 6]
for item in my_generator:print(item)  # 1 2 3 4 5 6

 生成器函数:

定义:含有yield语句的函数,返回值为生成器对象。

调用生成器函数将返回一个生成器对象,不执行函数体,调用迭代器对象的next()方法时才执行生成器函数, 每次执行到yield语句时返回数据,暂时离开,待下次调用next()方法时继续从离开处继续执行。

yield原理大致为:将yield语句之前的代码放入next函数中,之后的数据作为next函数的返回值。

生成器函数的代码案例:

def generator_func():list_nums = [1, 2, 3, 4, 5, 6]for item in list_nums:yield itemdef_generator = generator_func()
# 第一次迭代
for item in def_generator:print(item)  # 1 2 3 4 5 6# 第二次迭代
for item in def_generator:print(item)  # 

上面的generator_func函数 与 上面我们写的MyGenerator类型 做的是同一件事,MyGenerator是生成器的原理。通过上面生成器原理我们可以知道,生成器既是一个可迭代对象,又是一个迭代器。但是我们每次迭代生成器的时候,都是使用同一个生成器对象,当我们迭代过一次生成器对象时,生成器对象的 index指针已经指向最后一个,当我们再次遍历生成器对象时,生成器对象的__next__会抛出StopIteration来直接终止迭代。

生成器表达式:

定义:用推导式形式创建生成器对象。

代码案例:

# 生成器表达式
generator_nums = (i for i in range(5))
print(generator_nums.__next__())  # 0

 内置生成器:

枚举函数 enumerate

使用代码案例:

# enumerate 枚举函数 (生成器)
list_nums = [1, 2, 3]
for item in enumerate(list_nums):print(item)  # (0, 1) (1, 2) (2, 3)for i, item in enumerate(list_nums):print(i, item)  # 0 1, 1 2, 2 3

 zip

使用代码案例:

# zip 压缩 (生成器)
list_keys = ['name', 'age', 'sex']
list_values = ['tan', '22', 'nan']for item in zip(list_keys, list_values):print(item)  # ('name', 'tan') ('age', '22') ('sex', 'nan')# 字典转换
dict_person = dict(zip(list_keys, list_values))
print(dict_person)
dict_person = {k: v for k, v in zip(list_keys, list_values)}
print(dict_person)# 常用于矩阵转置
list_map = [[1, 2, 3, 4],[1, 2, 3, 4],[1, 2, 3, 4],[1, 2, 3, 4]
]
print([list(item) for item in zip(*list_map)]) 
# [[1, 1, 1, 1], [2, 2, 2, 2], [3, 3, 3, 3], [4, 4, 4, 4]]

 让我们来看看几道常考的面试题吧

面试题:

        1.请简述迭代器和生成器的却别。

                答:迭代器只有__next__函数,只负责生成下一个元素,

                        可迭代对象每次被for时都会调用__iter__函数创建新迭代器,

                        生成器既有__next__函数也有__iter__函数,但__iter__函数返回自身对象,

                        所以生成器对象第二次参与for循环时不再执行。

        2.请简述生成器表达式和列表推导式的区别。

                答:首先生成器表达式和列表推导式在语法上只有中括号和小括号之分,

                        列表推导式更擅长于对数据的增删改,但所有数据占用内存空间。

                        生成器表达式会产生生成器对象,即使产生大量数据也只存储当前,

                        不存之前数据,不占内存。

http://www.lryc.cn/news/263173.html

相关文章:

  • Vue项目搭建过程
  • 系统分析师(软考)知识点整理(一)
  • 2021年数维杯国际大学生数学建模D题2021年电影市场票房波动模型分析求解全过程文档及程序
  • Kubernetes 的用法和解析 -- 5
  • HTML选择题试题——附答案
  • html之CSS的高级选择器应用
  • elementui+ <el-date-picker type=“datetime“/>时间组件的当前时间的180天之内的禁止选择处理
  • 全网好听的BGM都在这里下载,赶紧收藏好了
  • Spark编程实验一:Spark和Hadoop的安装使用
  • 代理和AOP
  • Solidity-3-类型
  • 【mask转json】文件互转
  • 华清远见嵌入式学习——ARM——作业1
  • 如何在公网环境使用固定域名远程访问内网BUG管理系统协同办公
  • k8s pod网络排查教程
  • Apollo Planning——换道:LANE_CHANGE_DECIDER
  • Python 爬虫之简单的爬虫(三)
  • 为突发事件提供高现势性数据支撑!大势智慧助力中山市2023应急测绘保障演练举行
  • 图片速览 OOD用于零样本 OOD 检测的 CLIPN:教 CLIP 说不
  • a16z:加密行业2024趋势“无缝用户体验”
  • C# WPF上位机开发(属性页面的设计)
  • macOS 安装 oh-my-zsh 后 node 报错 command not found : node
  • AI 绘画 | Stable Diffusion 视频数字人
  • 《代码随想录》--二叉树(一)
  • shell编程-数组与运算符详解(超详细)
  • Vim入门
  • 动态加载库
  • React中渲染html结构---dangerouslySetInnerHTML
  • 计网02-计算机网络参考模型
  • 模块测试:确保软件质量的关键步骤