什么是最“python”的方法迭代列表块?

  • 问题:
  • 我有一个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”,不过,这让我怀疑还有一种更像Python的方式来处理这种情况。该列表在迭代后被丢弃,因此不需要保留它。也许这样更好?在

    while ints:
    foo += ints[0] * ints[1] + ints[2] * ints[3]
    ints[0:4] = []

    不过,还是不太“感觉”对。公司名称:-/

    相关问题:How do you split a list into evenly sized chunks in Python?

  • 答案:
  • 修改自recipessection of Python’sfrom 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'

    注意:在Python2上,请使用izip_longest而不是zip_longest