python迭代器和生成器

迭代器

#可以被netxt()函数调用不断返回一个值的对象成为迭代器:Iterator
#迭代器是访问集合元素的一种方式,从集合第一个元素开始(用next()方法)访问就不能回退,便于循环遍历一些较大的数据集合节省内存和时间。

一个简单的迭代器:
numbers = iter([1,2,3])
print(numbers)
print(numbers.__next__())
print(numbers.__next__())

Result:<list_iterator object at 0x1021777b8>
            1
            2        

 生成器

# 通过列表生成式,我们可以直接创建一个列表。但是,受到内存限制,列表容量肯定是有限的。
#如果我们仅仅需要访问前面几个元素,那后面绝大多数元素占用的空间都白白浪费了。
#所以,如果列表元素可以按照某种算法推算出来,那我们是否可以在循环的过程中不断推算出后续的元素呢?
#这样就不必创建完整的list,从而节省大量的空间。在Python中,这种一边循环一边计算的机制,称为生成器:generator。
#一个简单的生成器:
  >>> g = (x * for in range(10))
  >>> g
<generator object <genexpr> at 0x1022ef630>
 
#一个函数返回的是一个迭代器,这个函数就是一个生成器.
# 主要作用是保持函数的执行状态,可以中断函数的执行然后继续.


def cash_money (number):
    while number > 0:
        number -= 100
        yield 100
        print("取了100元!")

atm= cash_money(500)
print(type(atm))
print(atm.__next__())
print(atm.__next__())
print("去吃饭")#中断了函数的循环,去执行另外的任务.
print(atm.__next__()) #继续生成器中的循环 这个很强大.

而在实际操作中,我们并不用不停的__next__(),而是用for循环即可遍历生成器:

>>> g = (x * x for x in range(10))
>>> for n in g:
...     print(n)
...
0
1
4
9
16
25
36
49
64
81

 总结:

 1 我们已经知道,可以直接作用于for循环的数据类型有以下几种:
 2 
 3 一类是集合数据类型,如list、tuple、dict、set、str等;
 4 
 5 一类是generator,包括生成器和带yield的generator function。
 6 
 7 这些可以直接作用于for循环的对象统称为可迭代对象:Iterable。
 8 
 9 可以使用isinstance()判断一个对象是否是Iterable对象:
10 
11 
12 
13 >>> from collections import Iterable
14 >>> isinstance([], Iterable)
15 True
16 >>> isinstance({}, Iterable)
17 True
18 >>> isinstance('abc', Iterable)
19 True
20 >>> isinstance((x for x in range(10)), Iterable)
21 True
22 >>> isinstance(100, Iterable)
23 False
51_陆雅亮
原文地址:https://www.cnblogs.com/cyalu/p/6022395.html