#生成器 ''' 1.什么是生成器 通过列表推导式,可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。 而且,创建一个包含100万个元素的列表,占用很大的存储空间。如果我们仅仅需要访问前面几个元素 ,后面元素的占用存储空间就被浪费了。 所以,如果列表元素可以按照某种算法推算出来,那我们就可以在循环当中不断地推导它,生成元素。 这样就不必创建完整的list,从而大大节省了存储空间。 在python中,这种一边循环一边计算的机制,称为生成器:generator. ''' ''' list1=[] for i in range(10):#若要取1000万中的某个偶数,都遍历出来的话会占用太大内存空间 if i%2==0: l.append(i) print(list1) ''' #结果同上 [0, 2, 4, 6, 8] # list2=[i for i in range(0,10,2)] # print(list2) #结果同上 [0, 2, 4, 6, 8] # list3=[i for i in range(10) if i%2 is 0] # print(list3) ''' 以上三种都是列表生成式(列表推导式) ''' ''' 列表生成器后面的元素没有生产 0 ''' #第一种方法,把列表生成式的[]改成() # print(next(g))#可以通过next(生成器对象)获利生成器的下一个返回值。 g=(i for i in range(10) if i%2 is 0) print(g)#<generator object <genexpr> at 0x10410d0a0> print(next(g))#0,后面的元素没有生产 print(next(g))#0,2 后面的元素没有生产 # for i in range(len(g)):#因为g是生成器,元素并没有都生成出来,所以len(g)肯定不对 # print(next(g)) ''' 生成器保存的是算法!!!!!!!!!每次调用next(g),就计算出g的下 一个元素的值,直接计算到最后一个元素,如果没有更多的元素时,抛出StopIteration异常。 ''' #在实际编程当中,使用最多的是,将生成器以for方式来使用 #通过for迭代,拿到元素,不用担心StopIteration异常 for i in g: print(i)
Python3-生成器与列表推导式的区别
最新推荐文章于 2024-05-22 18:12:53 发布