zoukankan      html  css  js  c++  java
  • 迭代器

    迭代器是一次性的

    1、之前用while循环和for迭代列表l

    l=['a','b','c','d','e']
    i=0
    #用while循环打印出l
    while i<len(l):
        print(l[i])
        i+=1
    #用for循环打印出l
    for i in range(len(l)):
        print(l[i])
    

    2、可迭代对象(Iterable)

      先了解一下可迭代对象(Iterable),可以直接作用于for循环的对象统称为可迭代对象,有两种方法判断一个对象是否为可迭代对象:一是可以使用isinstance()判断一个对对象是否是Iterable对象(再用这个方法的时候一定记得调用模块);另一种是Python内置方法中有 .__iter__ 方法,如果能引用该方法的对象都是可迭代对象(.__iter__方法调用后的执行结果就是迭代器):

    from collections import Iterable
    print(isinstance([],Iterable))
    # True    列表是可迭代对象
    print(isinstance({},Iterable))
    # True    字典是可迭代对象
    print(isinstance('abc',Iterable))
    # True    字符串是可迭代对象
    print(isinstance((x for x in range(10)),Iterable))
    # True    生成器是可迭代对象
    print(isinstance(100,Iterable))
    # False    数字不是可迭代对象

    l=['a','b','c','d','e']
    l.__iter__()#能够调用__iter__说明l是可迭代对象
    ------------------------------------------
    #重点是__iter__()函数的作用
    l.__iter__()等同于调用iter(l)函数
    我们把函数运行结果赋值给i即:
    i=l.__iter__ 或者 i=iter(l)
    此时i就是迭代器,i就是迭代器,i就是迭代器

    3、迭代器(Iterator)

      可以被next()函数调用并不断返回下一个值的对象称为迭代器:Iterator 

      由定义就可以看出Iterator特性就是可以被next()调用所以判断是不是迭代器也同样有两种方法:

    from collections import Iterator
    print(isinstance((x for x in range(10)), Iterator))
    # True    生成器是迭代器
    print(isinstance([], Iterator))
    # False    列表不是迭代器
    print(isinstance({}, Iterator))
    # False    字典不是迭代器
    print(isinstance('abc', Iterator))
    # False    字符串不是迭代器

    l=['a','b','c','d','e']
    l不能调用.__next__方法,所以l不是迭代器

    4、总结可迭代对象(Iterable)与迭代器(Iterator)的区别

      迭代器:  

          独有.__next__方法

          也有.__iter__方法

          迭代器.__iter__()后还是迭代器

      

      可迭代对象:

          有.__iter__方法

      补充:文件句柄既能被next()函数调用又能被iter()函数调用,所以文件既是迭代器,又是可迭代对象

         字符串,列表,元组,字典,集合都不是迭代器,是可迭代对象

         整形不是可迭代对象,所以更不可能是迭代器

    5、迭代器while循环简单举例

    d={'a':1,'b':2,'c':3}
    i=d.__iter__()
    #i=iter(d)#和上面的等式一模一样   i就是迭代器
    print(i.__next__())#等同于下面
    print(next(i))#等同于上面
    print(i.__next__())
    print(i.__next__())#因为字典中的key只有3个,所以在这里会报错,因为超出了范围
    
    ---------------------------------------------------
    #报错内容是StopIteration,下面就一起消除这个报错吧
    
    d={'a':1,'b':2,'c':3}
    i=d.__iter__()#这是一个iter函数,等同于iter(d)  i就是迭代器
    #i=iter(d)#和上面的等式一模一样   i就是迭代器
    while True:                     
        try:   #try...except捕捉异常,看是否出现StopIteration这个异常,如果出现执行break,相当于一个if判断
            print(next(i))
        except StopIteration:
            break
    
    列表的例子:
    
    l=['a','b','c','d','e']
    i=l.__iter__()
    # i=iter(i)
    while True:
        try:                        #try...except捕捉异常
            print(next(i))
        except StopIteration:
            break

    文件的例子:
    f=open("a.txt","r")
    i=f.__iter__()
    while True:
    try:
    print(next(i),end="")
    except StopIteration:
    break

    6、迭代器for循环简单举例

    d={'a':1,'b':2,'c':3}
    for k in d:#for循环在这里做的事可以理解为 d=d.__iter__(),牛逼!
        print(k)
    #而且for循环自动加了next()函数,自动next下一个,牛逼!
    #而且for循环把while循环当中的try...except所做的是给做了,牛逼!
    
    s={1,2,3,4}#for循环列表
    for i in s:
        print(i)
    
    with open("a.txt","r") as f:
        for line in f:
            print(line,end="") 

    7、for循环与while循环小结

      上边的三个强大功能

      不是索引的取值就是迭代器方式的取值

      任何for循环能够完成的while循环都能够完成

    8、为什么要用迭代器

      优点:1.迭代器提供了一种不依赖于索引的取值方式,这样就可以遍历那些没有索引的可迭代对象(比如字典,集合,文件) 

         2.迭代器与列表相比更节省内存,是惰性计算的,时刻保持内存中只有一条在运行

      缺点:1.永远无法获取迭代器的长度,使用不如列表索引取值灵活

         2.迭代器是一次性的,next()只能往后取值,取完就没有了,但是for一次就搞完了

    9、为什么要把文件句柄设为一个迭代器

      因为Python是一门简洁的语言,列表,字符串,字典等等只能放到内存中,只有文件能永久保存,而且文件不排除有特别大的,为了避免内存炸掉把他作为一个可迭代对象,一点一点看,read应该就

      

  • 相关阅读:
    博客园设置自定义页面[布局][样式]
    linux的hostname文件目录
    mybatis底层源码分析之--配置文件读取和解析
    Enum的使用
    easyUI datagrid笔记
    软工实践第二次作业-黄紫仪
    软工实践第一次作业-黄紫仪
    第五次作业--原型设计
    作业三
    作业二
  • 原文地址:https://www.cnblogs.com/wuyongqiang/p/6694800.html
Copyright © 2011-2022 走看看