如何解决以块为单位迭代列表的最“pythonic”方式是什么?
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
脚本,它将整数列表作为输入,我需要一次处理四个整数。不幸的是,我无法控制输入,否则我会将其作为四元素元组列表传入。目前,我正在以这种方式对其进行迭代:
for i in range(0,len(ints),4):
# dummy op for example code
foo += ints[i] * ints[i + 1] + ints[i + 2] * ints[i + 3]
不过,它看起来很像“C-think”,这让我怀疑有一种更 Pythonic
的方式来处理这种情况。该列表在迭代后被丢弃,因此不需要保留。也许这样的事情会更好?
while ints:
foo += ints[0] * ints[1] + ints[2] * ints[3]
ints[0:4] = []
不过,仍然不太“感觉”正确。:-/
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。