【Python】Python迭代器与生成器的区别(详细讲解)

简介: 【Python】Python迭代器与生成器的区别(详细讲解)


👉博__主👈:米码收割机

👉技__能👈:C++/Python语言

👉公众号👈:测试开发自动化【获取源码+商业合作】

👉荣__誉👈:阿里云博客专家博主、51CTO技术博主

👉专__注👈:专注主流机器人、人工智能等相关领域的开发、测试技术。



在 Python 中,迭代器(Iterators)和生成器(Generators)都是用于处理可迭代对象的概念,但它们有一些关键的区别。让我们来看看它们的特点和区别:

1. 迭代器(Iterators)

  • 迭代器是一个实现了迭代协议的对象,可以通过内置函数iter()来创建。它主要用于遍历或访问集合(如列表、元组、集合、字典等)中的元素,以及处理大型数据集合时节省内存。
  • 迭代器的基本方法是__iter__()__next__()(在 Python 2 中是next())。__iter__()方法返回迭代器对象本身,并且__next__()方法返回下一个元素,如果没有更多元素则引发StopIteration异常。
  • 迭代器是惰性的,即每次只在需要时产生一个元素,不会提前将所有元素生成并保存在内存中。

假设我们有一个列表,我们想遍历该列表并计算其中所有元素的平方和。在这种情况下,我们可以使用迭代器来逐个获取列表中的元素并进行计算。

# 使用迭代器计算列表中元素的平方和
def square_sum(iterable):
    iterator = iter(iterable)
    result = 0
    try:
        while True:
            element = next(iterator)
            result += element ** 2
    except StopIteration:
        pass
    return result
my_list = [1, 2, 3, 4, 5]
total_square_sum = square_sum(my_list)
print(total_square_sum)  # 输出:55 (1 + 4 + 9 + 16 + 25)

运行结果:


2. 生成器(Generators)

  • 生成器是一种特殊类型的迭代器,使用函数和yield语句来定义。它允许在迭代过程中保存状态,从而使得函数可以在后续调用中继续执行,并返回生成的值,而不是将所有结果一次性返回。
  • 生成器的函数使用yield语句来产生值,而不是return语句。当函数中遇到yield时,会暂停执行并返回一个值给调用者,但函数的状态仍然保留,以便在下一次调用时从上次暂停的位置继续执行。
  • 生成器可以通过函数调用来使用,就像普通函数一样,但是当生成器函数被调用时,它不会立即执行,而是返回一个生成器对象,通过调用next()函数或使用for循环来逐步获取生成的值。
  • 生成器函数可以节省大量内存,因为它们一次只生成一个值,并且不会在内存中保存生成的所有元素。

使用生成器来实现同样的功能,在每次调用时生成一个元素的平方,并保留状态直到下一次调用。

# 使用生成器计算列表中元素的平方和
def square_generator(iterable):
    for element in iterable:
        yield element ** 2
my_list = [1, 2, 3, 4, 5]
squared_values = square_generator(my_list)
# 使用for循环获取生成器的值并计算平方和
total_square_sum = sum(squared_values)
print(total_square_sum)  # 输出:55 (1 + 4 + 9 + 16 + 25)

运行结果:


3. 总结:

这两个示例得出的结果是相同的,但实现方式有所不同。在第一个示例中,我们使用迭代器逐个获取列表中的元素,并且计算整个平方和之后才返回结果。而在第二个示例中,我们使用生成器逐步计算每个元素的平方,并且在生成器中保留了状态,从而实现了节省内存的效果。

使用迭代器时,我们一次获取并处理一个元素,而使用生成器时,我们按需生成并处理每个元素,保留了计算状态,从而能够节省内存,并且可以处理大量的数据集合。

迭代器是一种通用的抽象概念,而生成器是一种特殊类型的迭代器,使用函数和yield语句来实现。生成器在处理大量数据和需要保存状态的情况下非常有用,因为它们能够惰性地产生值并节省内存。相比之下,迭代器通常用于遍历普通的可迭代对象。无论是迭代器还是生成器,它们都是在处理大型数据集合和节省内存方面的有用工具。



相关文章
|
3月前
|
开发者 Python
Python代码设计:使用生成器替代回调函数
本文探讨了在处理大文件时计算MD5值的实现方法,并展示了如何通过回调函数、生成器和类等方式输出进度。首先介绍了通过回调函数更新进度的方式,然后优化为使用生成器简化调用者代码,最后对比了两种方式的优缺点。虽然生成器使代码更简洁,但在异常处理上不如回调函数灵活。作者通过实例分析,帮助开发者根据需求选择合适的方式。
76 16
|
3月前
|
Python
[oeasy]python086方法_method_函数_function_区别
本文详细解析了Python中方法(method)与函数(function)的区别。通过回顾列表操作如`append`,以及随机模块的使用,介绍了方法作为类的成员需要通过实例调用的特点。对比内建函数如`print`和`input`,它们无需对象即可直接调用。总结指出方法需基于对象调用且包含`self`参数,而函数独立存在无需`self`。最后提供了学习资源链接,方便进一步探索。
89 17
|
8月前
|
存储 开发者 Python
Python 中的数据结构与其他编程语言数据结构的区别
不同编程语言都有其设计理念和应用场景,开发者需要根据具体需求和语言特点来选择合适的数据结构
178 55
|
9月前
|
存储 索引 Python
Python生成器、装饰器、异常(2)
【10月更文挑战第16天】
110 1
Python生成器、装饰器、异常(2)
|
8月前
|
大数据 数据处理 开发者
Python中的迭代器和生成器:不仅仅是语法糖####
本文探讨了Python中迭代器和生成器的深层价值,它们不仅简化代码、提升性能,还促进了函数式编程风格。通过具体示例,揭示了这些工具在处理大数据、惰性求值及资源管理等方面的优势。 ####
|
9月前
|
Python
Python生成器、装饰器、异常
【10月更文挑战第15天】
65 2
|
8月前
|
JavaScript 前端开发 算法
python中的列表生成式和生成器
欢迎来到瑞雨溪的博客,这里是一位热爱JavaScript和Vue的大一学生的天地。通过自学前端技术2年半,现正向全栈开发迈进。如果你从我的文章中受益,欢迎关注,我将持续更新高质量内容,你的支持是我前进的动力!🎉🎉🎉
93 0
|
8月前
|
存储 程序员 数据处理
深入理解Python中的生成器与迭代器###
本文将探讨Python中生成器与迭代器的核心概念,通过对比分析二者的异同,结合具体代码示例,揭示它们在提高程序效率、优化内存使用方面的独特优势。生成器作为迭代器的一种特殊形式,其惰性求值的特性使其在处理大数据流时表现尤为出色。掌握生成器与迭代器的灵活运用,对于提升Python编程技能及解决复杂问题具有重要意义。 ###
|
9月前
|
机器学习/深度学习 缓存 Linux
python环境学习:pip介绍,pip 和 conda的区别和联系。哪个更好使用?pip创建虚拟环境并解释venv模块,pip的常用命令,conda的常用命令。
本文介绍了Python的包管理工具pip和环境管理器conda的区别与联系。pip主要用于安装和管理Python包,而conda不仅管理Python包,还能管理其他语言的包,并提供强大的环境管理功能。文章还讨论了pip创建虚拟环境的方法,以及pip和conda的常用命令。作者推荐使用conda安装科学计算和数据分析包,而pip则用于安装无法通过conda获取的包。
697 0
|
9月前
|
存储 大数据 数据处理
理解Python中的生成器:高效迭代的秘密
【10月更文挑战第8天】理解Python中的生成器:高效迭代的秘密
86 0

推荐镜像

更多