python中迭代器的基本方法_Python 迭代器

python中迭代器的基本方法_Python 迭代器Python 迭代器迭代器是可以迭代的对象 在本教程中 您将学习迭代器的工作原理以及如何使用 iter 和 next 方法构建自己的迭代器 Python 中的迭代器是什么 迭代器在 Python 中无处不在 它们在 for 循环 理解 生成器等中优雅地实现 但却隐藏在眼皮底下 Python 中的 Iterator 只是一个可以迭代的对象 一个将返回数据的对象 一次返回一个元素 从技术上讲 Python

Python 迭代器

迭代器是可以迭代的对象。 在本教程中,您将学习迭代器的工作原理以及如何使用__iter__和__next__方法构建自己的迭代器。

Python中的迭代器是什么?

迭代器在Python中无处不在。它们在for循环,理解,生成器等中优雅地实现,但却隐藏在眼皮底下。

Python中的Iterator只是一个可以迭代的对象。一个将返回数据的对象,一次返回一个元素。

从技术上讲,Python 迭代器对象必须实现两个特殊方法,__iter__()和__next__()统称为迭代器协议。

如果我们可以从对象获得迭代器,则该对象称为可迭代。Python中的大多数内置容器(例如:list,tuple,string等)都是可迭代的。

iter()函数(也就是__iter__()方法)从它们返回一个迭代器。

通过Python中的迭代器进行迭代

我们使用该next()函数手动遍历迭代器的所有项目。 当我们到达末尾并且没有更多数据要返回时,它将引发StopIteration。 以下是一个示例。。

示例# 定义一个列表

my_list = [4, 7, 0, 3]

# 使用iter()获得迭代器

my_iter = iter(my_list)

 使用iter()获得迭代器

#输出 4

print(next(my_iter))

#输出 7

print(next(my_iter))

 next(obj)与obj .__ next __()相同

#输出 0

print(my_iter.__next__())

#输出 3

print(my_iter.__next__())

 这将引起错误,没有项目剩下

next(my_iter)

一种自动迭代的更优雅的方法是使用for循环。使用此方法,我们可以迭代可以返回迭代器的任何对象,例如列表,字符串,文件等。>>> for element in my_list:

…     print(element)

4

7

0

3

for循环实际上如何工作?

正如我们在上面的示例中看到的那样,for循环能够自动遍历列表。

实际上,for循环可以迭代任何可迭代的对象。让我们仔细看看如何for在Python中实际实现循环。for element in iterable:

# 对元素做点什么

实际上是实现为。# 创建一个迭代器对象iterable

iter_obj = iter(iterable)

# 无限循环

while True:

try:

# 获取下一项

element = next(iter_obj)

# 对元素做点什么

except StopIteration:

# 如果引发StopIteration,则从循环中断

break

因此,在内部,for循环通过在iterable上调用iter()创建一个迭代器对象iter_obj。

具有讽刺意味的是,这个for循环实际上是一个无限的while循环。

在循环内部,它调用next()来获取下一个元素,并使用这个值执行for循环的主体。当所有的项都用完后,StopIteration被抛出,它在内部被捕获,循环结束。注意,任何其他类型的异常都会通过。

用Python构建自己的迭代器

在Python中从头开始构建迭代器很容易。我们只需要实现这些方法__iter__()和__next__()。

__iter__()方法返回迭代器对象本身。如果需要,可以执行一些初始化。

__next__()方法必须返回序列中的下一项。在到达终点时,以及在随后的调用中,它必须引发StopIteration。

这里,我们展示了一个示例,它将在每次迭代中为我们提供2的次幂。幂指数从0到用户设置的数字。

示例class PowTwo:

“””实现迭代器的类

二的幂”””

def __init__(self, max = 0):

self.max = max

def __iter__(self):

self.n = 0

return self

def __next__(self):

if self.n <= self.max:

result = 2  self.n

self.n += 1

return result

else:

raise StopIteration

现在,我们可以创建一个迭代器,并如下进行迭代。>>> a = PowTwo(4)

>>> i = iter(a)

>>> next(i)

1

>>> next(i)

2

>>> next(i)

4

>>> next(i)

8

>>> next(i)

16

>>> next(i)

Traceback (most recent call last):

StopIteration

我们还可以使用for循环来迭代迭代器类。>>> for i in PowTwo(5):

…     print(i)

1

2

4

8

16

32

Python无限迭代器

迭代器对象中的项不必耗尽。可能有无限的迭代器(永远不会结束)。在处理这样的迭代器时,我们必须小心。

这是一个演示无限迭代器的简单示例。

内置函数 iter()可以用两个参数调用,其中第一个参数必须是可调用对象(函数),第二个参数是标记。迭代器调用这个函数,直到返回的值等于标记值为止。>>> int()

0

>>> inf = iter(int,1)

>>> next(inf)

0

>>> next(inf)

0

我们可以看到int()函数始终返回0。因此,将其作为iter(int,1)传递将返回一个迭代器,该迭代器调用int()直到返回值等于1。这永远不会发生,并且我们得到一个无限迭代器。

我们还可以构建自己的无限迭代器。理论上,以下迭代器将返回所有奇数。

示例class InfIter:

“””无限迭代器返回所有

奇数”””

def __iter__(self):

self.num = 1

return self

def __next__(self):

num = self.num

self.num += 2

return num

运行如下。>>> a = iter(InfIter())

>>> next(a)

1

>>> next(a)

3

>>> next(a)

5

>>> next(a)

7

等等…

在这些类型的无限迭代器上进行迭代时,请小心包含终止条件。

使用迭代器的优点是节省了资源。如上所示,我们无需将整个数字系统存储在内存中就可以获得所有奇数。从理论上讲,我们可以在有限内存中包含无限项。

迭代器还使我们的代码看起来很酷。

有一种在Python中创建迭代器的简便方法。要了解更多信息,请访问:Python生成器yield。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/217422.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 上午9:36
下一篇 2026年3月18日 上午9:36


相关推荐

  • 走近webpack(0)–正文之前的故事

    在前端工作的过程中,只要你接触过vue,angular,react,gulp就一定知道webpack或者听说过或者使用过webpack,但是或许你对webpack的使用方法并不是十分了解,只是会用写好

    2022年3月25日
    43
  • linux将目录移动到指定目录下_shell获取文件所在路径

    linux将目录移动到指定目录下_shell获取文件所在路径摘要腾兴网为您分享:第七应用,flash29,信息来电闪光灯,优惠购,实况足球2018,汕大附一,同学聚会简单通知书,cajviewer,惠普deskjet1010,英魂之刃,运动世界,建行大学,爱奇艺会员,sketchup渲染器,电脑尺子,中俄边境游,山东政务服务网等知识经验教程,欢迎大家关注腾兴网。linux系统下,用户根据需求来进行各项操作,有小伙伴想移动文件,操作起来不大容易,linux…

    2022年10月5日
    7
  • 求三角形面积——C语言

    求三角形面积——C语言C 语言 利用海伦公式求三角形面积代码如下 include stdio h include math h voidmain floata b c p doubleS printf 请输入三边长度 n scanf f f f amp a amp b amp c if a b gt c amp amp b c gt a amp amp a c gt b p a b c 2 S sq math h stdio h

    2026年3月19日
    3
  • ALLURE架构整理

    ALLURE架构整理ALLURE1.开始安装1.1.安装命令行1.1.1.Linux1.1.2.MacOSX1.1.3.Windows1.1.4.手动安装2.报告结构2.1.总览页面2.2.类别2.3.测试套2.4.图表2.5.时间刻度2.6.功能2.7.包2.8测试用例页面3.Pytest与Allure3.1.安装3.2.用法示例:3.3.基本报告3.4.支持的Pytest功能XfailskipifFixtures和finalizersParametrization3.5AllureFeatu

    2022年7月26日
    18
  • 量化进阶——量化交易模型的“钝化”与“圣杯”[通俗易懂]

    量化进阶——量化交易模型的“钝化”与“圣杯”[通俗易懂]阅读原文:http://club.jr.jd.com/quant/topic/1326857京东金融官方资讯QQ群:417082141有什么想咨询的都可以来询问我们哦钝化的烦恼常有人提到量化交易模型的“钝化”问题,通俗的说,也就是一个模型从赚大钱变为不赚钱,甚至亏损的一个过程。甚至在海洋部落那样高手云集的社会中,不少高人眼里,钝化是每个量化交易模型都会很快发生的事,赚钱机

    2022年6月26日
    39
  • 满二叉树、完全二叉树、平衡二叉树、最优二叉树

    满二叉树、完全二叉树、平衡二叉树、最优二叉树一 满二叉树 一棵二叉树的结点要么是叶子结点 要么它有两个子结点 如果一个二叉树的层数为 K 且结点总数是 2 k 1 则它就是满二叉树 二 完全二叉树 若设二叉树的深度为 k 除第 k 层外 其它各层 1 k 1 的结点数都达到最大个数 第 k 层所有的结点都连续集中在最左边 这就是完全二叉树 三 平衡二叉树 它或者是一颗空树 或它的左子树和右子树的深度之差 平衡因子 的绝对值不超过 1 且它的左子树和右子树都是一颗平衡二叉树

    2025年6月20日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号