Python-迭代访问列表的最“ pythonic”方法是什么?

我有一个Python脚本,该脚本接受一个整数列表作为输入,我需要一次处理四个整数。不幸的是,我无法控制输入,或者将其作为四元素元组的列表传递。目前,我正在以这种方式对其进行迭代:

for i in xrange(0, len(ints), 4):

# dummy op for example code

foo += ints[i] * ints[i + 1] + ints[i + 2] * ints[i + 3]

不过,这看起来很像“C-think”,这让我怀疑有一种更像蟒蛇的方式来处理这种情况。列表在迭代后被丢弃,因此不需要保留它。也许这样更好?

while ints:

foo += ints[0] * ints[1] + ints[2] * ints[3]

ints[0:4] = []

不过,仍然感觉不太正确。

回答:

从Python的itertools文档的recipes部分修改:

from itertools import zip_longest

def grouper(iterable, n, fillvalue=None):

args = [iter(iterable)] * n

return zip_longest(*args, fillvalue=fillvalue)

示例

用伪代码保持示例简洁。

grouper('ABCDEFG', 3, 'x') --> 'ABC' 'DEF' 'Gxx'

注意:在Python 2上,请使用izip_longest代替zip_longest。

以上是 Python-迭代访问列表的最“ pythonic”方法是什么? 的全部内容, 来源链接: utcz.com/qa/405290.html

回到顶部