Python中的迭代器你了解吗

 更新时间:2023年05月24日 09:54:13   作者:答案永恒  
迭代器是一种特殊的对象,它实现了迭代协议,允许按照一定的顺序逐个访问元素,本文就来带大家深入了解一下Python中迭代器的使用,需要的可以参考下

for loop和迭代器

在Python中,for循环是一种常用的迭代结构,用于遍历可迭代对象中的元素。迭代器是一种特殊的对象,它实现了迭代协议,允许按照一定的顺序逐个访问元素。

for循环和迭代器之间存在密切的关系,实际上,for循环是基于迭代器工作的。当使用for循环遍历可迭代对象时,Python会在内部自动创建一个迭代器对象,并使用该迭代器来逐个获取元素,直到所有元素都被访问完毕。

for loop里面in后面那个东西必须是一个iterable, 也就是必须是一个可迭代对象

下面是一个示例,演示了for循环和迭代器之间的关系:

fruits = ['apple', 'banana', 'orange']

# 使用for循环遍历列表元素
for fruit in fruits:
    print(fruit)

# 上述代码等价于下面的迭代器方式
iterator = iter(fruits)  # 创建迭代器对象
while True:
    try:
        fruit = next(iterator)  # 获取下一个元素
        print(fruit)
    except StopIteration:
        break

在上面的示例中,我们首先使用for循环遍历了列表fruits中的元素,打印出每个水果的名称。然后,我们手动创建了一个迭代器对象iterator,并使用next()函数逐个获取元素,直到遇到StopIteration异常,表示所有元素都被访问完毕。

可以看到,使用for循环可以简化迭代过程,不需要显式地创建迭代器对象和处理StopIteration异常。Python的许多内置对象(如列表、元组、字典等)都是可迭代的,因此可以直接在for循环中使用它们。

列表

lst = [1, 2, 3]
for i in lst:
    print(i)

字典

d = {"a": 1, "b": 2}
for i in d:
    print(i)

文件操作

with open(my.txt, "r") as f:
    for i in f:
        print(i)

除了内置的可迭代对象,你还可以自定义迭代器类,实现自己的迭代逻辑。这样,你就可以在for循环中使用自定义的迭代器来遍历特定的数据结构或实现特定的迭代行为。

for loop的背后核心是迭代器可迭代对象

迭代器和可迭代对象

https://docs.python.org/3/glossary.html

在Python中,可迭代对象和迭代器是两个相关但不同的概念。

可迭代对象(Iterable)是指实现了__iter__()方法的对象,或者实现了__getitem__()方法且可按照顺序访问的对象。这两者都是为了保证它可以在iter这个函数的作用下返回一个iterator。可迭代对象可以被迭代,也就是可以在for循环中使用。常见的可迭代对象包括列表、元组、字符串、字典、集合等。

迭代器(Iterator)是一种特殊的对象,它实现了迭代协议,具有__iter__()__next__()方法。迭代器用于逐个返回可迭代对象中的元素,每次调用__next__()方法都会返回下一个元素,如果没有更多元素,则引发StopIteration异常。迭代器对象还可以在迭代过程中记录迭代状态。

每当使用for循环来遍历一个可迭代对象时,Python会在内部自动创建一个迭代器对象,并调用其__next__()方法来逐个获取元素。因此,可以说for循环是基于迭代器工作的。

下面是一个示例,演示了可迭代对象和迭代器的概念:

fruits = ['apple', 'banana', 'orange']

# fruits是可迭代对象,可以在for循环中使用
for fruit in fruits:
    print(fruit)

# 创建迭代器对象
iterator = iter(fruits)

# 调用迭代器的__next__()方法获取下一个元素
print(next(iterator))  # 输出:'apple'
print(next(iterator))  # 输出:'banana'
print(next(iterator))  # 输出:'orange'
print(next(iterator))  # 引发StopIteration异常

在上面的示例中,fruits是一个可迭代对象,我们可以直接在for循环中使用它来遍历元素。同时,我们也可以使用iter()函数手动将可迭代对象转换为迭代器对象,并使用next()函数来逐个获取元素。当所有元素都被访问完毕时,继续调用next()函数会引发StopIteration异常。

需要注意的是,迭代器是一种一次性的对象,即在迭代过程中,一旦迭代器返回了所有元素,它就会耗尽,无法再次使用。如果想重新遍历可迭代对象,需要重新创建迭代器对象。

  • 一个iterable更像是一个数据的保存者,一个container,它是可以没有状态的,它可以完全不知道你这个iterator数到哪了,它需要有能力产生一个iterator。
  • iterator一定是有状态的,但是它并不需要实现一个container,它当然内部肯定知道它代表这个iterable里面是什么数据。iterator必须要有__next__这个method。这个method保证它在被next作用的时候可以返回下一个iterable。

自定义一个可迭代对象和对应的迭代器-链表

#! -*-conding=: UTF-8 -*-
# 2023/5/22 18:43

class NodeIter:
    def __init__(self, node):
        self.curr_node = node

    def __next__(self):
        if self.curr_node is None:
            raise StopIteration
        node, self.curr_node = self.curr_node, self.curr_node.next

        return node


class Node:
    def __init__(self, name):
        self.name = name
        self.next = None

    def __iter__(self):
        return NodeIter(self)


node1 = Node("node1")
node2 = Node("node2")
node3 = Node("node3")

node1.next = node2
node2.next = node3


if __name__ == '__main__':
    for node in node1:
        print(node.name)

如果我们想在for loop里面使用链表的话,那我们就要自己把链表变成一个iterable。

这段代码演示了如何自定义一个可迭代对象和对应的迭代器。

首先,我们定义了一个Node类,表示一个节点,每个节点具有一个名称和一个指向下一个节点的引用。Node类实现了__iter__()方法,该方法返回一个迭代器对象。

然后,我们定义了一个NodeIter类作为迭代器,它接收一个节点对象作为参数,并在__init__()方法中初始化当前节点。NodeIter类实现了__next__()方法,用于返回下一个节点。在每次调用__next__()方法时,它会将当前节点作为结果返回,并将当前节点更新为下一个节点。当没有更多节点时,抛出StopIteration异常。

最后,在if __name__ == '__main__':条件下,我们使用自定义的可迭代对象和迭代器进行遍历。通过for node in node1:的语法,会自动调用node1对象的__iter__()方法获取迭代器,并通过迭代器逐个获取节点,并打印节点的名称。

运行以上代码,输出结果为:

node1
node2
node3

这个示例展示了如何自定义可迭代对象和迭代器,并在for循环中使用它们实现自定义的迭代逻辑。

到此这篇关于Python中的迭代器你了解吗的文章就介绍到这了,更多相关Python迭代器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python使用BeautifulSoup4修改网页内容的实战记录

    Python使用BeautifulSoup4修改网页内容的实战记录

    BeautifulSoup除了可以查找和定位网页内容,还可以修改网页,下面这篇文章主要给大家介绍了关于Python使用BeautifulSoup4修改网页内容的相关资料,需要的朋友可以参考下
    2022-05-05
  • Python中关于logging模块的学习笔记

    Python中关于logging模块的学习笔记

    在本篇文章里小编给大家整理的是一篇关于Python中logging模块相关知识点内容,有兴趣的朋友们可以参考下。
    2020-06-06
  • 对python csv模块配置分隔符和引用符详解

    对python csv模块配置分隔符和引用符详解

    今天小编就为大家分享一篇对python csv模块配置分隔符和引用符详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-12-12
  • Django实现登录随机验证码的示例代码

    Django实现登录随机验证码的示例代码

    登录验证码是每个网站登录时的基本标配,这篇文章主要介绍了Django实现登录随机验证码的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • Python实现并行抓取整站40万条房价数据(可更换抓取城市)

    Python实现并行抓取整站40万条房价数据(可更换抓取城市)

    本文主要是以房价网房价信息爬虫为例,对Python实现整站40万条房价数据并行抓取(可更换抓取城市)的方法进行分析介绍。需要的朋友一起来看下吧
    2016-12-12
  • Flask框架Flask-Login用法分析

    Flask框架Flask-Login用法分析

    这篇文章主要介绍了Flask框架Flask-Login用法,结合实例形式分析了Flask-Login插件进行登录验证的相关操作技巧与注意事项,需要的朋友可以参考下
    2018-07-07
  • Python实战之自动发送邮件的实现

    Python实战之自动发送邮件的实现

    自动发送邮件能应用于许多场景,下面本文就来和大家讲讲怎么用Python构建一个自动发送邮件的脚本。感兴趣的小伙伴可以动手尝试一下
    2022-05-05
  • 如何用Python 加密文件

    如何用Python 加密文件

    这篇文章主要介绍了如何用Python 加密文件,帮助大家更好的理解和使用python,感兴趣的朋友可以了解下
    2020-09-09
  • Python使用Pandas读写Excel实例解析

    Python使用Pandas读写Excel实例解析

    这篇文章主要介绍了Python使用Pandas读写Excel实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • 使用Django2快速开发Web项目的详细步骤

    使用Django2快速开发Web项目的详细步骤

    这篇文章主要介绍了使用Django2快速开发Web项目的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-01-01

最新评论