Pisałem odpowiedź na this question, gdy zauważyłem, że moja prosta implementacja nie przyniosła poprawnych wyników. Podczas polowania dół błąd, zauważyłem następujące:Dlaczego zip() upuszcza wartości mojego generatora?
In [1]: import itertools
In [2]: gen = itertools.cycle((0,1,2))
In [3]: zip(gen, range(3))
Out[3]: [(0, 0), (1, 1), (2, 2)]
In [4]: zip(gen, range(3))
Out[4]: [(1, 0), (2, 1), (0, 2)]
z jakiegokolwiek powodu, gen
„s next()
metoda nazywa się jeden raz additioinal. Aby to zilustrować, użyłem następujących czynności:
class loudCycle(itertools.cycle):
def next(self):
n = super(loudCycle, self).next()
print n
return n
In [6]: gen = loudCycle((0,1,2))
In [7]: zip(gen, range(3))
0
1
2
0
Out[7]: [(0, 0), (1, 1), (2, 2)]