【Python教程】生成器
【Python教程】生成器
gh_1d7504e4dee1
回复:python,领取Python面试题。分享Python教程,Python架构师教程,Python爬虫,Python编程视频,Python脚本,Pycharm教程,Python微服务架构,Python分布式架构,Pycharm注册码。
整理:python架构师
前面我们已经好几次提到了生成器的概念。这里对其简要介绍一下。
有时候,序列或集合内的元素的个数非常巨大,如果全制造出来并放入内存,对计算机的压力是非常大的。比如,假设需要获取一个10**20次方如此巨大的数据序列,把每一个数都生成出来,并放在一个内存的列表内,这是粗暴的方式,有如此大的内存么?
如果元素可以按照某种算法推算出来,需要就计算到哪个,就可以在循环的过程中不断推算出后续的元素,而不必创建完整的元素集合,从而节省大量的空间。在Python中,这种一边循环一边计算出元素的机制,称为生成器:generator。
前面我们说过,通过圆括号可以编写生成器推导式:
>
>> g = (x * x
for
x
in
range(1, 4))
>
>> g
<generator object <genexpr> at 0x1022ef630>
可以通过next()函数获得generator的下一个返回值,这点和迭代器非常相似:
>>
> next(g)
1
>>
> next(g)
4
>>
> next(g)
9
>>
> next(g)
Traceback (most recent call last):
File
"<pyshell#14>"
, line
1
,
in
<
module
>
next
(g)
StopIteration
点击领取Python面试题手册
Python从入门到进阶知识手册
但更多情况下,我们使用for循环。
for
i
in
g:
print
(i)
除了使用生成器推导式,我们还可以使用yield关键字。
在 Python中,使用yield返回的函数会变成一个生成器(generator)。在调用生成器的过程中,每次遇到yield时函数会暂停并保存当前所有的运行信息,返回yield的值。并在下一次执行next()方法时从当前位置继续运行。
# 斐波那契函数
def
fibonacci
(n)
:
a, b, counter =
0
,
1
,
0
while
True
:
if
counter > n:
return
yield
a
# yield让该函数变成一个生成器
a, b = b, a + b
counter +=
1
fib = fibonacci(
10
)
# fib是一个生成器
print(type(fib))
for
i
in
fib:
print(i, end=
" "
)
程序员技术交流群
扫码进群记得备注: 城市、昵称和技术方向 。
阅读更多
-
用树莓派打造便携式 PyPI 服务器
-
【Python教程】迭代器
-
离谱!两高中生用AI生成luo照,疯狂「变现」
-
2023年血糖新标准公布,不是3.9-6.1,快来看看你的血糖正常吗? 2023-02-07
-
2023年各省最新电价一览!8省中午执行谷段电价! 2023-01-03
-
GB 55009-2021《燃气工程项目规范》(含条文说明),2022年1月1日起实施 2021-11-07
-
PPT导出高分辨率图片的四种方法 2022-09-22
-
2023年最新!国家电网27家省级电力公司负责人大盘点 2023-03-14
-
全国消防救援总队主官及简历(2023.2) 2023-02-10
-
盘点 l 中国石油大庆油田现任领导班子 2023-02-28
-
我们的前辈!历届全国工程勘察设计大师完整名单! 2022-11-18
-
关于某送变电公司“4·22”人身死亡事故的快报 2022-04-26
