我有一个任意长度的列表,我需要将它分成相同大小的块并对其进行操作.有一些明显的方法可以做到这一点,比如保留一个计数器和两个列表,当第二个列表填满时,将它添加到第一个列表并清空下一轮数据的第二个列表,但这可能非常昂贵.
我想知道是否有人对任何长度的列表都有一个很好的解决方案,例如使用生成器.
我一直在寻找有用的东西,itertools但我找不到任何明显有用的东西.但是可能会错过它.
我有一个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]
Run Code Online (Sandbox Code Playgroud)
它看起来很像"C-think",这让我怀疑有更多的pythonic方式来处理这种情况.迭代后会丢弃该列表,因此无需保留.也许这样的事情会更好吗?
while ints:
foo += ints[0] * ints[1] + ints[2] * ints[3]
ints[0:4] = []
Run Code Online (Sandbox Code Playgroud)
但是,仍然没有"感觉"正确.: - /
我想将一个int数组(像这样[1, 1, 2, 1])转换为字符串("1121").
什么是最好的(最pythonic)方式?
我总是可以这样做,然后删除额外的括号:
>>> str([1, 2, 1, 1])
'[1, 2, 1, 1]'
Run Code Online (Sandbox Code Playgroud)
或者我可以这样做:
s = ""
for i in [1, 2, 1, 1]:
s += s(i)
Run Code Online (Sandbox Code Playgroud)
但这两种方法都有点不稳定.有没有更好的方法呢?
为了记录,我自然对所有版本的Python感兴趣,但我正在研究py2.7并且更喜欢使用这个版本的答案.