
本文旨在解决如何将一个计算加法的函数转换为生成器,使其能够分批次返回结果列表。我们将探讨如何正确实现生成器函数,并提供一个可配置批次大小的示例,确保所有计算结果都能被正确处理并返回。
在Python中,生成器是一种特殊的函数,它使用 yield 关键字来逐步产生值,而不是一次性返回所有结果。这在处理大量数据时非常有用,因为它可以减少内存占用,并允许按需生成数据。
问题: 如何将一个普通的计算函数转换为生成器,使其能够分批次返回结果列表,而不是一次性返回所有结果?
解决方案: 关键在于正确地管理批次大小,并在生成器函数结束时处理剩余的结果。
立即学习“Python免费学习笔记(深入)”;
以下是一个示例,展示了如何创建一个生成器函数 compute_add_generator,该函数接收一个 batch_size 参数,并返回指定大小的结果批次:
import itertools
def compute_add_generator(batch_size):
assert batch_size > 0 # 确保 batch_size 大于 0
data = range(5)
batch = []
for x, y in itertools.permutations(data, 2):
ans = x + y
batch.append(ans)
if len(batch) == batch_size:
yield batch # 返回一个批次
batch = [] # 重置批次
# 处理剩余的元素
if batch:
yield batch代码解释:
report = []
for res in compute_add_generator(3):
report.append(res)
print(f"{report=}")输出:
report = [[1, 2, 3], [4, 1, 3], [4, 5, 2], [3, 5, 6], [3, 4, 5], [7, 4, 5], [6, 7]]
通过使用生成器函数,我们可以有效地将计算任务分解为更小的批次,从而减少内存占用,并提高程序的性能。关键在于正确地管理批次大小,并在生成器函数结束时处理剩余的结果。这个方法对于处理大型数据集和需要逐步生成结果的场景非常有用。
以上就是Python:从生成器函数返回列表的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号