【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语句来实现。生成器在处理大量数据和需要保存状态的情况下非常有用,因为它们能够惰性地产生值并节省内存。相比之下,迭代器通常用于遍历普通的可迭代对象。无论是迭代器还是生成器,它们都是在处理大型数据集合和节省内存方面的有用工具。



相关文章
|
2天前
|
大数据 Python
python中的推导式、生成器(二)
python中的推导式、生成器(二)
|
2天前
|
索引 Python 容器
python中的推导式、生成器(一)
python中的推导式、生成器(一)
|
2天前
|
Python 容器
python匿名函数、迭代器、高阶函数(二)
python匿名函数、迭代器、高阶函数(二)
|
2天前
|
索引 Python
python匿名函数、迭代器、高阶函数(一)
python匿名函数、迭代器、高阶函数(一)
|
5天前
|
Python
在Python Web开发过程中:`is`和`==`在Python中的区别是什么?
【4月更文挑战第25天】Python的`is`与`==`用于比较。`is`检查对象是否相同(内存地址一致),而`==`检查值是否相等。例如,`a = [1, 2, 3]`,`b = a`,`c = [1, 2, 3]`,则`a is b`和`a == b`均为True,但`a is c`为False,`a == c`为True,因`a`和`b`引用同一对象,而`a`和`c`值虽等但对象不同。
7 1
|
13天前
|
缓存 大数据 数据处理
Python迭代器、生成器和装饰器探究
【4月更文挑战第2天】 迭代器是遍历集合元素的对象,实现`__iter__()`和`__next__()`方法。示例中自定义迭代器`MyIterator`用于生成整数序列。 - 生成器简化了迭代器实现,利用`yield`关键词实现状态保存,减少内存占用。示例中的`my_generator`函数即为一个生成器。 - 装饰器用于修改函数行为,如日志记录、性能分析。装饰器`my_decorator`在函数调用前后添加额外代码。
28 0
|
14天前
|
大数据 数据处理 开发者
深入理解Python中的迭代器和生成器
Python中的迭代器和生成器是实现高效循环和处理大型数据集的重要工具。本文将深入探讨迭代器和生成器的概念、原理以及在实际开发中的应用场景,帮助读者更好地理解和利用这些强大的工具。
|
18天前
|
存储 大数据 Python
「Python系列」Python迭代器与生成器
Python迭代器是一个可以记住遍历的位置的对象。迭代器对象必须实现两个方法,`__iter__()` 和 `__next__()`。字符串、列表或元组等数据类型都是可迭代对象,但它们不是迭代器,因为它们没有实现 `__next__()` 方法。
14 0
|
26天前
|
大数据 Python
请解释 Python 中的生成器的工作原理。
Python中的生成器通过`yield`语句实现函数执行的暂停与恢复。调用生成器函数时不立即执行,返回生成器对象。通过迭代该对象逐次获取值,每次遇到`yield`,函数暂停并返回结果,下次迭代时从暂停处继续。生成器按需生成值,节省内存,适合处理大数据。以下是一个简单的生成器示例,生成并打印0到4的数字: ```python def generate_numbers(): for i in range(5): yield i for num in generate_numbers(): print(num) ``` 如有更多问题,欢迎提问!😄
15 6
|
3月前
|
索引 Python 容器
解释Python中的迭代器和生成器的优势和劣势。
解释Python中的迭代器和生成器的优势和劣势。
35 2