• python 迭代器与可迭代对象


    迭代器一定是可迭代对象,但是可迭代对象不一定是迭代器。

    list,truple,str这些都是可迭代对象,但是他们不一定是迭代器。迭代器本身不知道自己要执行多少次,所以可以理解为不知道有多少个元素,每调用一次next(),就会往下走一步,是惰性的。

    迭代器提供了一种不依赖索引取值的方式,这样可以遍历没有索引的可迭代对象,比如字典、集合、文件等等,加载这一个元素至内存中随后释放,相比之下相当节省内存,这也是迭代器最大的优点,但是我们没有办法获取迭代器的长度,而且只能往后依次取值。

    这也是for循环遍历取值实现的机制。


    怎么创建迭代器?

    只要对象本身有__iter__方法,那它就是可以迭代的。

    d={'a':1,'b':2,'c':3}
    d.__iter__()

    执行对象下的__iter__方法得到的就是迭代器

    d={'a':1,'b':2,'c':3}
    a=d.__iter__()
    print(type(a))
    print(next(a))
    print(next(a))
    print(next(a))
    print(next(a))


    <class 'dict_keyiterator'> #执行结果
    a #第一次print(next(a))结果
    b #第二次print(next(a))结果
    .....

    StopIteration #直到取完所有的值会提示这个错误,

    如果不想要这个错误出现怎么办?

    d={'a':1,'b':2,'c':3}
    i=iter(d)
    while True:
    try: #错误会出现的代码
    print(next(i))
    except StopIteration: #如果从这一句里面捕捉到StopIteration 这个错误提示,如果出现执行break
    break

     还有更简单的方式

    d={'a':1,'b':2,'c':3}
    d.__iter__

    for k in d: #这里的d默认帮我们执行了d.__iter__(),并且程序自动帮我们捕捉StopIteration 这个错误,不需要我们手工写进去
    print(k)

    怎么判断对象是可迭代对象,还是迭代器?

    这里我们需要一个模块来帮助我们

    判断是不是可以迭代,用Iterable

    from collections import Iterable,Iterator    #我们需要用到的模块

    s='hello'
    l=[1,2,3]
    t=(1,2,3)
    d={'a':1}
    set1={1,2,3,4}
    f=open('a.txt')

    # #都是可迭代的
    s.__iter__() #都有__iter__方法
    l.__iter__()
    t.__iter__()
    d.__iter__()
    set1.__iter__()
    f.__iter__()

    python官方推荐 判断方式
      是否是可以迭代的
    print(isinstance(s,Iterable))
    print(isinstance(l,Iterable))
    print(isinstance(t,Iterable))
    print(isinstance(d,Iterable))
    print(isinstance(set1,Iterable))
    print(isinstance(f,Iterable))

      是否是迭代器,用Iterator
    print(isinstance(s,Iterator))
    print(isinstance(l,Iterator))
    print(isinstance(t,Iterator))
    print(isinstance(d,Iterator))
    print(isinstance(set1,Iterator))
    print(isinstance(f,Iterator))
  • 相关阅读:
    操作系统进程调度策略
    runnable & callable
    leetcode 124 二叉树中的最大路径和
    leetcode 24 两两交换链表中的节点
    leetcode 93 复原IP地址
    C++ 11 move
    leetcode 64 最小路径和
    leetcode 1143 最长公共子序列
    leetcode 528 按权重随机选择
    数据挖掘面试题(1)
  • 原文地址:https://www.cnblogs.com/MYue/p/8999015.html
Copyright © 2020-2023  润新知