[oldboy-django][5python基础][高级特性]Iterator迭代器

# 区分可迭代对象iterable, 迭代器iterator, 生成器generator
    a. iterable
        可直接用for循环的对象,都称为可迭代对象,
        from collections import Iterable
        使用isinstance(a, Iterable)判断a对象是否为可迭代对象

        因此,list, dict, str都是iterable
    b. iterator
        凡是可作用于Next()函数的对象,都是迭代器类型,表示一个惰性计算的序列
        记住迭代器是有状态的,用过一轮之后,就不要反复使用了
    c. generator
        生成器也是迭代器, 但迭代器不是生成器。
        生成器一般用于:当函数需要返回一个序列,这个时候最好将函数改造成generator,
        这样做会比返回一个列表更省内存

    d. iterator 和iterable区别
        迭代器是惰性的,用多少生产多少;可迭代对象是一下全部返回,不管用到用不到.
        集合数据类型如list、dict、str等是Iterable但不是Iterator,
        不过可以通过iter()函数获得一个Iterator对象。

        在python中迭代器对象是一个数据流, 数据流是有序的但是不能提前知道它的长度,
        只能不断通过Next计算下一个数据,所以迭代器是惰性的。

    e. 如何将List,dict, str变成迭代器
        使用iter(list)方法
        from collections import Iterator
        l = [1,2,3]
        s = iter(l)
        print(isinstance(s, Iterator))

# python中for循环机制 -- 迭代器协议
    - 迭代器协议(循环原理)
        python在for循环中遍历某种容器的内容时,比如for x in foo, python实际上会先调用iter(foo)
        将foo对象转成迭代器。
            a.  如果foo是迭代器,则会调用foo.__iter__方法,该方法返回foo本身.
            b.  如果foo是可迭代对象,则会生成一个迭代器

        然后后for循环中, 会调用内置的next方法(注意这个方法不是迭代器的方法),
        next方法会调用迭代器本身的__next__方法,直到元素耗尽产生StopIteration异常break出循环

    for x in [1,2,3,4]:
        print(x)

    等效于:
        it = iter([1,2,3,4])
        while True:
            try:
                x = next(it)
                print(x)
            except StopIteration as e:
                break


# 文件的read和xreadline区别
    read会读取文件所有内容到内存,占空间
    xreadline只有在循环的时候,才获取

    自己定义一个读文件的迭代器容器
    def NReadlines():
        with open('log','r') as f:
            while True:
                line = f.next()
                if line:
                    yield line
                else:
                    return

    for i in NReadlines():
        print i
View Code

 

posted @ 2017-11-21 13:30  liuzhipenglove  阅读(475)  评论(0编辑  收藏  举报