• 迭代器


    迭代器

    迭代器:不是函数,只是一个称呼而已

    x = 10  # 不是可迭代对象
    
    s = 'abc'
    s.__iter__()
    
    lt = [1, 2, 3]
    lt.__iter__()
    
    tup = (1,)
    tup.__iter__()
    
    dic = {'a': 1}
    dic.__iter__()
    
    se = {1}
    se.__iter__()
    
    fw = open('test.txt', 'a+', encoding='utf8')
    fw.seek(0, 0)
    fw.__iter__()
    
    # 除了数字类型,所有数据类型都是可迭代对象
    
    # 迭代器对象: 含有__iter__和__next__方法的对象就是迭代器对象
    
    
    # 为什么要有迭代器对象:提供了 不依赖索引取值的 手段
    
    #字符串
    s = 'abc'
    s_iter = s.__iter__()
    print(s_iter.__next__()) # a
    print(s[0]) # a
    print(s_iter.__next__()) # b
    print(s[1]) # b
    print(s_iter.__next__()) # c
    print(s[2]) # c
    
    
    #字典
    dic = {'a': 1, 'b': 2, 'c': 3}
    
    dic_iter=dic.__iter__()
    print(dic_iter.__next__()) # a # 迭代取值 --》 基于上一个值
    print(dic_iter.__next__()) # b 
    print(dic_iter.__next__()) # c 
    
    
    # 如果用c写,这就是for循环
    # for循环自动捕捉个数,用尽停止
     dic_iter = dic.__iter__()
     while True:
         try:
             print(dic_iter.__next__())
         except StopIteration:
             break
    # for循环原理(for循环本质就是一个while循环,只不过是一个一定可控的while循环)
    
    
    #文件
    fw = open('test.txt', 'a+', encoding='utf8')
    fw.seek(0, 0)
    fw.__iter__()
    
    fw_iter = fw.__iter__()
    print(fw_iter.__next__())
    print(fw_iter.__next__())
    print(fw_iter.__next__())
    
    # 总结
    
    # 可迭代对象: 含有__iter__方法叫做可迭代对象 --> 除了数字类型都是可迭代对象 --> 可迭代对象使用__iter__变成迭代器
    
    # 迭代器对象: 含有__iter__和__next__方法叫做迭代器对象 --> 只有文件时迭代器对象 --> 迭代器使用__iter__依然是迭代器
    
    # 可迭代对象不一定是迭代器对象; 迭代器对象一定是可迭代对象
    
  • 相关阅读:
    双链表( 初始化,建立,插入,查找,删除 )
    单链表(程序员宝典)
    单链表(建立、插入、删除、打印)
    Hive- 表
    Spark- 性能优化
    Spark- Checkpoint原理剖析
    Spark- 优化后的 shuffle 操作原理剖析
    Spark- Spark普通Shuffle操作的原理剖析
    Spark- Spark内核架构原理和Spark架构深度剖析
    Spark- Spark基本工作原理
  • 原文地址:https://www.cnblogs.com/jzm1201/p/12595292.html
Copyright © 2020-2023  润新知