izip
はかなり良いオプションですが、ここであなたがそれに不満を持っているので、いくつかの選択肢があります:
>>> def chunker(seq, size):
... return (tuple(seq[pos:pos+size]) for pos in xrange(0, len(seq), size))
...
>>> x = range(11)
>>> x
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
>>> chunker(x, 2)
<generator object <genexpr> at 0x00B44328>
>>> list(chunker(x, 2))
[(0, 1), (2, 3), (4, 5), (6, 7), (8, 9), (10,)]
>>> list(izip(x[1::2], x[::2]))
[(1, 0), (3, 2), (5, 4), (7, 6), (9, 8)]
あなたが見ることができるように、これは適切要素の不均一な量を扱うという利点があり、これあなたにとって重要であるかどうかは分かりません。 itertools documentation itselfからこのレシピもあります:
>>> def grouper(n, iterable, fillvalue=None):
... "grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx"
... args = [iter(iterable)] * n
... return izip_longest(fillvalue=fillvalue, *args)
...
>>>
>>> from itertools import izip_longest
>>> list(grouper(2, x))
[(0, 1), (2, 3), (4, 5), (6, 7), (8, 9), (10, None)]
Oは本当にこのソリューションが好きです、ありがとう! – uolot
ああ、なぜコメントを編集できないのですか? "私は本当に好きです..." – uolot