迭代器与生成器


这一部分待加强!
                (一)迭代器
    
一:简介

    迭代是Python最强大的功能之一,是访问集合元素的一种方式。
    迭代器是一个可以记住遍历的位置的对象。
    迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。
    迭代器只能往前不会后退。

    迭代器有两个基本的方法:iter() 创建迭代器对象和 next()访问迭代器。
    字典、字符串、列表或元组对象都可用于创建迭代器

二:迭代器的创建

    ①把一个类作为一个迭代器使用需要在类中实现两个方法 __iter__() 与 __next__()
    ②__iter__() 方法返回一个特殊的迭代器对象,
    这个迭代器对象实现了 __next__() 方法
    并通过 StopIteration 异常标识迭代的完成。
    ③__next__() 方法(Python 2 里是 next())会返回下一个迭代器对象

三:迭代器协议的后台机制

    for element in (1, 2, 3):
            print(element)
    
    在后台,for 语句在容器对象中调用 iter() 。
    该函数返回一个定义了 __next__() 方法的迭代器对象,它在容器中逐一访问元素。
    没有后续的元素时, __next__() 抛出一个 StopIteration 异常,
    通知 for 语句循环结束。
    可以用内建的 next() 函数调用 __next__() 方法;

    了解了迭代器协议的后台机制,就可以很容易的给自己的类添加迭代器行为。
    定义一个 __iter__() 方法,使其返回一个带有 __next__() 方法的对象。
    如果这个类已经定义了 __next__() ,那么 __iter__() 只需要返回 self:

三:迭代器使用的必要性
    
    列表效率高,但是需要将内容一次性读入,可能增加内存的负担,
    如果列表太大,内存溢出。
    range 返回一个列表
    xrange 返回一个对象

                (二)生成器

一:简介

    ①在 Python 中,使用了 yield 的函数被称为生成器(generator)
    跟普通函数不同的是,生成器是一个返回迭代器的函数,
    只能用于迭代操作,更简单点理解生成器就是一个迭代器
    ②在调用生成器运行的过程中,每次遇到 yield 时函数会暂停,
    并保存当前所有的运行信息,返回 yield 的值,
    并在下一次执行 next() 方法时从当前位置继续运行。

二:创建生成器

    ①一个简单的生成器:my_generator = (x*x for x in range(4))
    和列表解析式只是括号不同,大数据处理时代替列表解析式。
    ②和return的区别:一般的函数都是止于return,作为生成器的函数,由于有了yield,
    遇到他则会暂时挂起,如果之后还有return,则直接抛出StopIteration异常。

三:本节最后一句:编程中可以不使用生成器。

 1 # ---------------------------------------------------------------------#
 2 # 迭代器的创建
 3 # ---------------------------------------------------------------------#
 4 import sys
 5 print("----------------------------迭代器-----------------------------")
 6 list1 = [1, 2, 3, 4]
 7 it = iter(list1)    # 创建迭代器对象
 8 print(next(it))     # 输出迭代器的下一个元素
 9 
10 # ---------------------------------------------------------------------#
11 # 迭代器的遍历
12 # ---------------------------------------------------------------------#
13 # 遍历方法一
14 list2 = [1, 2, 3, 4]
15 it = iter(list2)        # 创建迭代器对象
16 for x in it:
17     print(x, end=" ")   # 此处格式化输出的形式
18 
19 # 遍历方法二
20 list3 = (1, 2, 3, 4)
21 it = iter(list3)  # 创建迭代器对象
22 """
23 
24 
25 while True:
26     try:
27         print(next(it), end=" ")
28     except StopIteration:   # 用于标识迭代的完成,防止出现无限循环的情况
29         sys.exit()
30 """
31 # ---------------------------------------------------------------------#
32 # 写一个能够迭代的对象(给自己的类添加迭代对象)
33 # ---------------------------------------------------------------------#
34 
35 
36 class MyNumbers:
37     def __init__(self, n):
38         self.i = 0
39         self.n = n
40 
41     def __iter__(self):     # 核心,返回了迭代器本身即实现了__iter__方法的对象
42         return self
43 
44     def __next__(self):     # 含有next的对象就是迭代器本身
45         if self.i < self.n:
46             result_i = self.i
47             self.i += 1
48             return result_i
49         else:
50             raise StopIteration
51 
52 
53 x = MyNumbers(7)
54 y = iter(x)
55 for i in y:
56     print(i)
57 
58 
59 print("# ----------------------------生成器----------------------------- #")
60 
61 
62 def fibonacci(n):  # 生成器函数 - 斐波那契
63     a, b, counter = 0, 1, 0
64     while True:
65         if counter > n:
66             return
67         yield a
68         a, b = b, a + b
69         counter += 1
70 
71 
72 f = fibonacci(10)  # f 是一个迭代器,由生成器返回生成
73 
74 while True:
75     try:
76         print(next(f), end=" ")
77     except StopIteration:
78         sys.exit()

 









posted @ 2018-09-29 08:23  faithyiyo  阅读(294)  评论(0编辑  收藏  举报