Python之迭代器

本文通过文章同步功能推送至博客园,显示排版可能会有所错误,请见谅!

迭代器指对象提供了一个next方法,执行该方法要么放回迭代中的下一项,要么就引起一个Stopitertion错误,以终止迭代。

可迭代对象则是内部定义了一个__iter__()方法以实现迭代器协议的对象。 从迭代器定义上来,所有迭代器都应有next方法。可迭代对象并非迭代器,本质上,可迭代对象(如字符串、列表、元组、集合、字典、文件等)内部提供了一个__iter__()方法,使用__iter__()方法能将其转化为一个迭代器,进而支持next方法用于迭代。

在python中,for循环、sum、map和filter等函数实质上是使用迭代器协议。如for循环,接受一个可迭代对象,在实际处理时,先使用可迭代对象的__iter__()方法获得一个迭代器,然后在使用next方法迭代,直到返回最后一个值,for内置了处理Stopitertion错误的机制。

for i in list(range(101)):
    print(i)

上述for循环简单模拟处理如下:

Iter = range(101).__iter__()
while True:
    try:
        i = Iter.__next__()
        print(i)
    except Stopitertion:
        break

迭代器可以使用3种方式迭代

使用send()方法时,可以传入一个值给当前yield

知道了迭代器的特性,我们可以使用迭代器简单模拟实现一个列表对象的索引功能!

class LIST(list):
    '''新建一个LIST类,继承list类'''
    def find(self,n):
        """find方法用于索引取值"""
        i = 0
        iter = self.__iter__()     #将可迭代对象列表转为迭代器赋值给iter
        res = next(iter)           #使用迭代器的next方法
        while i != n:              #当计数器i不等于目标索引n时,使用next迭代
            res = next(iter)
            i += 1
        return res
num_list=LIST(i for i in range(100))       #定义一个LIST类的对象
res = num_list.find(50)            #调用LIST类中的find方法,取得索引号50的值
print(res)    #res = 50

posted @ 2019-09-08 17:54  秋叶红了  阅读(259)  评论(0编辑  收藏  举报