欢迎来到@一夜看尽长安花 博客,您的点赞和收藏是我持续发文的动力
对于文章中出现的任何错误请大家批评指出,一定及时修改。有任何想要讨论的问题可联系我:3329759426@qq.com 。发布文章的风格因专栏而异,均自成体系,不足之处请大家指正。
专栏:
文章概述:对 生成器Generator和列表生成式 的介绍
关键词:生成器Generator 列表生成式
本文目录:
Python生成器
生成器的基本概念
生成器是一个特殊类型的迭代器,它可以按需生成数据。生成器函数使用 yield
关键字来返回一个值,并在生成器的状态(包括局部变量)保留位置,使得下一次调用时可以从上次暂停的位置继续执行。
生成器函数
生成器函数是使用 def
定义的函数,但与普通函数不同,它使用 yield
关键字来返回值,而不是 return
。每次调用生成器函数时,函数会返回一个生成器对象,可以通过迭代来获取生成的值。
生成器函数和生成器对象啥关系 ?
生成器的工作原理
- 当你调用生成器函数时,它并不执行函数体内的代码,而是返回一个生成器对象。
- 当你开始迭代生成器对象时(通常通过
next()
函数),生成器函数开始执行,直到遇到yield
关键字。 - 每次执行到
yield
时,生成器函数会返回一个值,并暂停执行,保存当前的状态(包括局部变量的值)。 - 当再次调用
next()
函数时,生成器函数从上次暂停的位置继续执行,直到再次遇到yield
或者函数结束。
生成器的工作原理
- 当你调用生成器函数时,它并不执行函数体内的代码,而是返回一个生成器对象。
- 当你开始迭代生成器对象时(通常通过
next()
函数),生成器函数开始执行,直到遇到yield
关键字。 - 每次执行到
yield
时,生成器函数会返回一个值,并暂停执行,保存当前的状态(包括局部变量的值)。 - 当再次调用
next()
函数时,生成器函数从上次暂停的位置继续执行,直到再次遇到yield
或者函数结束。
假设需要一个序列,Seq 1 to 9000000
用range 实现
# [1,2,3,4,......]
for x in range(1, 9000000):
print(x)
# 但是range只有一个step可以控制
yield(生成)
#定义一个生成器函数
def mygenerator(x):
for x in range(n):
yield x**3
#实例化生成器
values = mygenerator(9000000)
#用next可以依次输出
print(next(values))
print(next(values))
print(next(values))
print(next(values))
print(next(values))
#实例化生成器
values = mygenerator(100)
#迭代输出值
for x in values:
print(x)
不管多少个数字,生成器的大小没有变
import sys
def mygenerator(x):
for x in range(n):
yield x**3
values = mygenerator(100)
print(sys.getsizeof(values))
values = mygenerator(1000000)
print(sys.getsizeof(values))
即使是无限多的数据也没有关系,因为每一次获得下一个数据都是产生出来的,不会去让内存溢出
infinite_sequence()
函数创建了一个生成器对象 values
。每次调用 next(gen)
,生成器会执行一次循环体并返回 result
的当前值
def infinite_sequence():
result = 1
while True:
yield result
result *= 5
values = infinite_sequence()
print(next(values))
print(next(values))
print(next(values))
print(next(values))
print(next(values))
生成器表达式
alist=list(range(1, 9000000))
gen_expr = ( a**(1/2) for a in alist)
生成器表达式返回生成器对象,按需生成值,节省内存,适合处理大数据集 ,直接生成可迭代对象
列表生成式
alist=list(range(1, 9000000))
gen_expr = [ a**(1/2) for a in alist]
列表生成式:
列表生成式有一个容器,会将生成的数据存放到容器里,容器返回可迭代对象
列表生成式返回的是一个完整的列表对象,其中包含所有生成的元素。这意味着列表生成式一次性生成并保存所有的值,占用的内存空间会比较大。