yield的作用及使用详解
时间:2025-12-02 14:56:56 213浏览 收藏
最近发现不少小伙伴都对文章很感兴趣,所以今天继续给大家介绍文章相关的知识,本文《Python中yield的作用及使用详解》主要内容涉及到等等知识点,希望能帮到你!当然如果阅读本文时存在不同想法,可以在评论中表达,但是请勿使用过激的措辞~
yield关键字使函数成为生成器,可暂停执行并按需返回值。生成器是特殊的迭代器,无需手动实现__iter__和__next__,通过yield自动保存状态,相比传统迭代器更简洁、内存友好。调用next()时,生成器从上次yield处继续执行,适用于大文件读取、斐波那契数列、数据流处理等场景,提升效率与可读性。

yield关键字在Python中扮演着生成器的核心角色。它允许函数暂停执行并返回一个值,而保留其状态,以便稍后可以从停止的地方继续执行。这使得你能够创建按需生成值的序列,而不是一次性将所有值存储在内存中。
Python生成器yield关键字详解:
生成器是一种特殊的迭代器,它不会一次性生成所有值,而是根据需要逐个生成。yield关键字是实现生成器的关键。
什么是生成器?它与迭代器有什么区别?
生成器本质上是一种特殊的迭代器。迭代器是一个对象,实现了__iter__和__next__方法,用于按顺序访问集合中的元素。生成器通过使用yield关键字来简化迭代器的创建过程。
主要区别在于:
- 实现方式: 迭代器通常需要定义一个类,并手动实现
__iter__和__next__方法。生成器则可以通过一个包含yield语句的函数来创建,更简洁。 - 内存占用: 迭代器和生成器都不会一次性加载所有数据到内存中,而是按需生成。但生成器在实现上更加轻量级,通常占用更少的内存。
- 状态保持: 生成器函数在每次调用
next()时,会从上次yield语句停止的地方继续执行,保留了函数的状态。
例如,以下是一个迭代器的例子:
class MyIterator:
def __init__(self, data):
self.data = data
self.index = 0
def __iter__(self):
return self
def __next__(self):
if self.index >= len(self.data):
raise StopIteration
value = self.data[self.index]
self.index += 1
return value
my_list = [1, 2, 3]
my_iterator = MyIterator(my_list)
for item in my_iterator:
print(item)而以下是一个生成器的例子:
def my_generator(data):
for item in data:
yield item
my_list = [1, 2, 3]
my_generator_object = my_generator(my_list)
for item in my_generator_object:
print(item)可以看到,生成器的代码更简洁。
yield关键字如何工作?深入理解生成器的执行流程
当一个函数包含yield关键字时,它就变成了一个生成器函数。调用生成器函数时,它不会立即执行函数体,而是返回一个生成器对象。
当对生成器对象调用next()方法时,生成器函数会开始执行,直到遇到yield语句。此时,函数会暂停执行,并将yield后面的值返回给调用者。同时,函数的状态会被保存下来。
下次调用next()方法时,函数会从上次暂停的地方继续执行,直到再次遇到yield语句。这个过程会一直重复,直到函数执行完毕,或者遇到return语句(此时会抛出StopIteration异常)。
例如:
def my_generator():
print("First")
yield 1
print("Second")
yield 2
print("Third")
gen = my_generator()
print(next(gen)) # 输出: First, 1
print(next(gen)) # 输出: Second, 2
print(next(gen)) # 输出: Third, StopIteration可以看到,每次调用next(),生成器函数都会执行到下一个yield语句,并返回一个值。
生成器的实际应用场景:如何利用yield优化代码?
生成器在处理大数据集、无限序列或需要按需生成数据的场景下非常有用。
- 读取大型文件: 可以使用生成器逐行读取大型文件,避免一次性将整个文件加载到内存中。
def read_large_file(file_path):
with open(file_path, 'r') as f:
for line in f:
yield line.strip()
for line in read_large_file('large_file.txt'):
print(line)- 生成斐波那契数列: 可以使用生成器无限生成斐波那契数列。
def fibonacci():
a, b = 0, 1
while True:
yield a
a, b = b, a + b
for num in fibonacci():
if num > 100:
break
print(num)- 数据流处理: 可以将生成器用于数据流处理管道,每个生成器负责一个特定的数据处理步骤。
def data_source():
for i in range(10):
yield i
def square(data):
for item in data:
yield item * item
def cube(data):
for item in data:
yield item * item * item
data = data_source()
squared_data = square(data)
cubed_data = cube(squared_data)
for item in cubed_data:
print(item)生成器可以显著提高代码的可读性和效率,尤其是在处理大数据或需要延迟计算的场景下。记住,使用yield的关键在于理解它如何暂停和恢复函数的执行,以及如何利用它来创建按需生成数据的迭代器。
今天关于《yield的作用及使用详解》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
347 收藏
-
464 收藏
-
290 收藏
-
112 收藏
-
324 收藏
-
429 收藏
-
348 收藏
-
391 收藏
-
324 收藏
-
340 收藏
-
292 收藏
-
109 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习