关于python中可迭代对象和迭代器的一些理解

不少python教程中,对python的解释不容易理解,本文记录本身的理解和体会,是对迭代器和生成器的初步理解python

1、关于迭代的认识

给定一个列表、元祖、字典、甚至字符串,咱们使用for去遍历,这样咱们叫迭代函数

  • 一、列表的迭代spa

    list1 = ['哈哈', '西西', '嘻嘻']
    for x in list1:
        print(x)
    复制代码
  • 二、列表中须要迭代出下标使用enumeratecode

    list1 = ['哈哈', '西西', '嘻嘻']
    for index, value in enumerate(list1):
        print(index, value)
    复制代码
  • 三、元祖和字符串的迭代与列表的相似,同样的可使用enumerate进行下标迭代对象

  • 四、字典的迭代方式一继承

    dict1 = {'name': '张三', 'age': 20, 'gender': '男'}
    for item in dict1:
        print(item)
    复制代码
  • 五、字典的迭代方式二教程

    dict1 = {'name': '张三', 'age': 20, 'gender': '男'}
    for key in dict1.keys():
        print(key)
    复制代码
  • 六、字典的迭代方式三字符串

    dict1 = {'name': '张三', 'age': 20, 'gender': '男'}
    for value in dict1.values():
        print(value)
    复制代码
  • 七、字典的迭代方式四get

    dict1 = {'name': '张三', 'age': 20, 'gender': '男'}
    for k, v in dict1.items():
        print(k, v)
    复制代码

2、可迭代与迭代器的区别

  • 一、可迭代通常均可以使用for来遍历string

  • 二、迭代器不单单可使用for遍历还可使用next()函数一次获取一个元素

  • 三、可迭代转换迭代对象使用iter(可迭代对象)

  • 四、判断可迭代对象与迭代器的方式

    from collections.abc import Iterator, Iterable
    # Iterable 表示可迭代对象
    # Iterator 表示迭代器
    list1 = [1, 2, 3]
    print(isinstance(list1, Iterator))
    print(isinstance(list1, Iterable))
    print(isinstance(iter(list1), Iterator))
    复制代码
  • 五、集合数据类型如listdictstr等是Iterable但不是Iterator,不过能够经过iter()函数得到一个Iterator对象

3、本身实现一个可迭代的对象

  • 一、方式一(在类中实现__getitem__魔法函数)

    from collections.abc import Iterator, Iterable
    
    
    class Company(object):
        def __init__(self, employee_list):
            self.employee = employee_list
    
        def __getitem__(self, item):
            return self.employee[item]
    
    
    if __name__ == "__main__":
        company = Company(['张三', '李四', '王五'])
        print(isinstance(company, Iterable))
        print(isinstance(company, Iterator))
        print(isinstance(iter(company), Iterator))
        for item in company:
            print(item)
    复制代码
  • 二、方式二(在类中实现__iter__魔法函数,须要结合__next__魔法函数)其实已是迭代器

    from collections.abc import Iterator, Iterable
    
    
    class Company(object):
        def __init__(self, employee_list):
            self.employee = employee_list
            self.index = 0
    
        def __iter__(self):
            return self
            
        def __next__(self):
            try:
                current_val = self.employee[self.index]
            except IndexError:
                raise StopIteration
            self.index += 1
            return current_val
    
    
    if __name__ == "__main__":
        company = Company(['张三', '李四', '王五'])
        print(isinstance(company, Iterable))
        print(isinstance(company, Iterator))
        for item in company:
            print(item)
    复制代码
  • 三、总结

    • 1.iter内置函数会调用__iter__魔法函数,若是没有__iter__ 魔法函数就会去调用__getitem__魔法函数
    • 经过isinstance(company, Iterable)判断对象是否可迭代
    • 经过isinstance(company, Iterator)判断对象是否为迭代器
    • 可迭代器对象不表明是迭代器,可是能够经过iter()函数将可迭代的转换为迭代器

4、自定义迭代器

  • 一、最简单也是最粗暴的方式,直接在类中实现两个魔法函数__iter____next__函数

    from collections import Iterable, Iterator
    
    
    class Foo(object):
        def __init__(self, start, stop):
            self.start = start
            self.stop = stop
    
        def __iter__(self):
            return self
    
        def __next__(self):
            if self.start > self.stop:
                raise StopIteration
            self.start += 1
            return self.start
    
    
    if __name__ == "__main__":
        foo = Foo(1, 5)
        print(isinstance(foo, Iterable))
        print(isinstance(foo, Iterator))
    复制代码
  • 二、单独定义一个类来继承迭代器,必须实现__next__魔法函数

    from collections.abc import Iterable, Iterator
    
    
    class MyInterator(Iterator):
        """ 定义一个迭代器 """
    
        def __init__(self, employee_list):
            self.iter_list = employee_list
            self.index = 0
    
        def __next__(self):
            try:
                word = self.iter_list[self.index]
            except IndexError:
                raise StopIteration
            self.index += 1
            return word
    复制代码
    class Company(object):
        def __init__(self, employee_list):
            self.employee = employee_list
            self.index = 0
    
        def __iter__(self):
            return MyInterator(self.employee)
    
    
    if __name__ == "__main__":
        company = Company(['张三', '李四', '王五'])
        print(isinstance(company, Iterator))
        print(isinstance(company, Iterable))
    复制代码
相关文章
相关标签/搜索