本文实例讲述了Python生成器定义与简单用法。分享给大家供大家参考,具体如下:
一、什么是生成器
在Python中,由于受到内存的限制,列表容量肯定是有限的。例如我们创建一个包含一亿个元素的列表,Python首先会在内存中开辟足够的空间来存储这个包含一亿个元素的列表,然后才允许用户去使用这个列表,这就可能会导致以下问题:
1、内存中没有足够的内存空间开存储这个列表,从而导致列表无法创建
2、即使列表成功创建,然而仍会消耗很长的时间,导致程序效率低下
3、若用户只想访问列表前面的几个元素,则后面列表绝大多数元素占用的空间就都白白浪费了
为了有效解决以上的问题,Python中引入了一种“一边循环,一边计算”的新机制,即当用户需要使用某个对象时,Python才根据事先设计好的规则开辟内存空间创建这个对象供用户使用,而不是像列表一样事先将所有的对象都创建完毕之后再提供给用户使用。这种机制在Python中成为生成器(generator)。
二、生成器的创建
A、生成器推到式
与列表推到式类似,只不过生成器推导式使用()而非[],并且最终返回的是生成器而非列表
g=((i+2)**2 for i in range(2,30)) #g是一个生成器print(g) #g为空,里面包含任何元素
运行结果:
<generator object <genexpr> at 0x0000000002263150>
B、yield关键字
在一个函数定义中包含yield关键字,则这个函数就不再是一个普通的函数,而是一个生成器(generator)
[说明]:yield指令可以暂停一个函数并返回其中间结果,使用该指令的函数将保存执行环境,并在必要时恢复
def fib(max): n,a,b=0,0,1 while n<max: #print(b) yield b a,b=b,a+b n+=1 return 'done'f=fib(6)print(f)
运行结果:
<generator object fib at 0x0000000002553150>
[注]:普通函数和变成生成器的函数的不同:
普通函数是顺序执行的,遇到return或是最后一行函数语句就返回。而变成生成器的函数在每次调用__next__()方法时执行,遇到yield语句返回,再次执行时从上次返回的yield语句处继续执行
f=fib(6)print(f)print(f.__next__())print(f.__next__())print('暂停一下')print(f.__next__())print(f.__next__())
运行结果:
<generator object fib at 0x00000000025631A8>
1
1
暂停一下
2
3
三、生成器方法(参考:伯乐在线)
1.close()方法:手动关闭生成器函数,后面的调用会直接返回StopIteration异常
def func(): yield 1 yield 2 yield 3g=func()g.__next__()g.close() #手动关闭生成器g.__next__() #关闭后,yield 2和yield 3语句将不再起作用
新闻热点
疑难解答