我试图在
Python 2.7.1上实现itertools.izip的反向功能.问题是我发现了一个问题,我没有解释.
解决方案1,iunzip_v1完美运行.但解决方案2. iunzip_v2,无法按预期工作.直到现在,我还没有找到关于这个问题的任何相关信息,并且阅读有关发电机的PEP,听起来它应该有效,但事实并非如此.
import itertools
from operator import itemgetter
def iunzip_v1(iterable):
_tmp, iterable = itertools.tee(iterable, 2)
iters = itertools.tee(iterable, len(_tmp.next()))
return tuple(itertools.imap(itemgetter(i), it) for i, it in enumerate(iters))
def iunzip_v2(iterable):
_tmp, iterable = itertools.tee(iterable, 2)
iters = itertools.tee(iterable, len(_tmp.next()))
return tuple((elem[i] for elem in it) for i, it in enumerate(iters))
结果:
In [17]: l
Out[17]: [(0, 0, 0), (1, 2, 3), (2, 4, 6), (3, 6, 9), (4, 8, 12)]
In [18]: map(list, iunzip.iunzip_v1(l))
Out[18]: [[0, 1, 2, 3, 4], [0, 2, 4, 6, 8], [0, 3, 6, 9, 12]]
In [19]: map(list, iunzip.iunzip_v2(l))
Out[19]: [[0, 3, 6, 9, 12], [0, 3, 6, 9, 12], [0, 3, 6, 9, 12]]
似乎iunzip_v2正在使用最后一个值,因此生成器在第一个生成器内创建时不保留值.
我错过了什么,我不知道是什么.
如果有什么事情可以让我澄清这种情况,请提前致谢
更新:
我在这里找到了解释PEP-289,我的第一次阅读是在PEP-255.
我试图实现的解决方案是懒惰的,所以:
zip(*iter) or izip(*...)
对我不起作用,因为* arg扩展了参数列表.