python核心编制之生成器

python核心编制之生成器

该文档仅用作学习笔记,转载请表明出处

什么是生成器

  • 通过列表生成式,我们可以直接创建一个列表,但是,收到内存的限制,列表容量肯定是有限的而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面的几个元素,那后面绝大多数元素占用的空间都白白浪费了,所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?这样就不必创建完整的list,从而节省大量的空间。
  • 在python中,这种一边循环一边计算的机制,称为生成器。generator。

创建生成器方法1

  • 要创建一个生成器,有很多方法,第一种方法很简单,只要把一个列表生成式的[]改成()
  • 案例v29:
'''
创建生成器方法1
'''

l = [x * 2 for x in range(5) ]
print(l)
L = (x * 2 for x in range(5) )
print(L)
for i in L:
    print(i)

输出的结果为:
在这里插入图片描述

创建生成器的第二种方法

案例v30:斐波那契数列。

from time import sleep

def feibonaqieFunc():
    a,b = 0,1
    while True:
        yield (b)
        a,b = b,a+b
        sleep(1)

a = feibonaqieFunc()
while True:
    print(next(a))
    sleep(0.1)

输出结果为:
在这里插入图片描述

send

  • 当执行到yield时,gen函数作用暂时保存,返回i的值;temp接受下次c.send(‘python’),send发送多来的值。c.next()等价c.send(None)
  • 案例31:
def gen():
    i = 0
    while i<5 :
        #yield i
        temp = yield i
        print(temp)
        i += 1
a = gen()
#next(a)
#next(a)
#next(a)
print(next(a))
print(next(a))
print(next(a))
print(next(a))
print(next(a))

输出结果为:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/lz13309833915/article/details/83090787
今日推荐