【发布时间】:2026-02-12 00:15:01
【问题描述】:
我一直在 Python 中使用生成器函数。我想写一个函数,它接受一个生成器,其值为元组,并返回一个生成器列表,其中每个生成器的值对应于原始元组中的一个索引。
目前,我有一个函数可以为元组中的硬编码数量的元素完成此操作。这是我的代码:
import itertools
def tee_pieces(generator):
copies = itertools.tee(generator)
dropped_copies = [(x[0] for x in copies[0]), (x[1] for x in copies[1])]
# dropped_copies = [(x[i] for x in copies[i]) for i in range(2)]
return dropped_copies
def gen_words():
for i in "Hello, my name is Fred!".split():
yield i
def split_words(words):
for word in words:
yield (word[:len(word)//2], word[len(word)//2:])
def print_words(words):
for word in words:
print(word)
init_words = gen_words()
right_left_words = split_words(init_words)
left_words, right_words = tee_pieces(right_left_words)
print("Left halves:")
print_words(left_words)
print("Right halves:")
print_words(right_words)
这会正确拆分生成器,导致 left_words 包含左半部分,而 right_words 包含右半部分。
当我尝试使用上面注释掉的行参数化要创建的生成器的数量时,问题就出现了。据我所知,它应该是等效的,但是当我改用该行时,left_words 和 right_words 最终都包含单词的右半部分,输出如下:
Left halves:
lo,
y
me
s
ed!
Right halves:
lo,
y
me
s
ed!
为什么会这样?我怎样才能实现想要的结果,即参数化生成器的分割数?
【问题讨论】:
标签: python scope functional-programming generator