将迭代器分组为大小为n的块的最具python风格的方法
可能重复:将迭代器分组为大小为n的块的最具python风格的方法,python,iterator,Python,Iterator,可能重复: 如果你有一个迭代器iter,它的值是i0,i1,i2,…,那么获得一个值为 [i0, i1, i2], [i3, i4, i5], ... 以上是对假设的groupby(iter,3)的输出,这是我能找到的最佳解决方案(需要itertools): 但是它感觉有点粗糙,而且很难阅读itertools模块有一个解决方法,叫做。以下是直接从itertools文档中复制的摘录 def grouper(n, iterable, fillvalue=None): "Collect d
如果你有一个迭代器
iter
,它的值是i0,i1,i2,…
,那么获得一个值为
[i0, i1, i2], [i3, i4, i5], ...
以上是对假设的
groupby(iter,3)
的输出,这是我能找到的最佳解决方案(需要itertools
):
但是它感觉有点粗糙,而且很难阅读itertools模块有一个解决方法,叫做。以下是直接从itertools文档中复制的摘录
def grouper(n, iterable, fillvalue=None):
"Collect data into fixed-length chunks or blocks"
# grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx
args = [iter(iterable)] * n
return izip_longest(fillvalue=fillvalue, *args)
仔细想想,它与@User792036提供的解决方案完全相似。实际上,它包含了一个填充值,并且在使用时看起来更漂亮,因为它是一个函数。更具体地说,它适用于任意可写性。对于不是块大小倍数的输入,这并不能以一般方式解决问题。izip基本上忽略了最后一块(而不是全部)项。
def grouper(n, iterable, fillvalue=None):
"Collect data into fixed-length chunks or blocks"
# grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx
args = [iter(iterable)] * n
return izip_longest(fillvalue=fillvalue, *args)