在Python中循环遍历列表中n个连续项

3

我需要在列表中迭代n个连续元素。

例如:

data = [1,2,3,4,5,6,7]

我需要了解:

1 2
2 3
3 4
4 5

或者:

1 2 3
2 3 4
3 4 5
4 5 6

有zip函数可以做到这一点吗?
6个回答

6

我不确定您具体需要什么,但可以尝试以下内容:

data = [1, 2, 3, 4, 5, 6, 7]

n = 3

[data[i:i+n] for i in range(len(data) - n + 1)]

# [[1, 2, 3], [2, 3, 4], [3, 4, 5], [4, 5, 6], [5, 6, 7]]

或者:

f = lambda data, n: [data[i:i+n] for i in range(len(data) - n + 1)]

for x, y, z in f([1, 2, 3, 4, 5, 6, 7], 3):
    print x, y, z

3

假设您总是在对列表或其他序列执行此操作,并且它不需要使用任意可迭代对象:

def group(seq, n):
    return (seq[i:i+n] for i in range(len(seq)-n+1))

例子:

>>> list(group([1,2,3,4,5,6,7], 2))
[[1, 2], [2, 3], [3, 4], [4, 5], [5, 6], [6, 7]]
>>> list(group([1,2,3,4,5,6,7], 3))
[[1, 2, 3], [2, 3, 4], [3, 4, 5], [4, 5, 6], [5, 6, 7]]

如果您需要对任意可迭代对象执行此操作(可能不支持len()或切片),您可以采用pairwise recipe进行调整:

from itertools import tee, izip

def group(iterable, n):
    "group(s, 3) -> (s0, s1, s2), (s1, s2, s3), (s2, s3, s4), ..."
    itrs = tee(iterable, n)
    for i in range(1, n):
        for itr in itrs[i:]:
            next(itr, None)
    return izip(*itrs)

>>> list(group(iter([1,2,3,4,5,6,7]), 2))
[(1, 2), (2, 3), (3, 4), (4, 5), (5, 6), (6, 7)]
>>> list(group(iter([1,2,3,4,5,6,7]), 3))
[(1, 2, 3), (2, 3, 4), (3, 4, 5), (4, 5, 6), (5, 6, 7)]

3

具体答案:

>>> zip(data,data[1:])
[(1, 2), (2, 3), (3, 4), (4, 5), (5, 6), (6, 7)]

一般性回答:
>>> def consecutives(data,per_set):
...   return zip(*[data[n:] for n in range(per_set)])
...
>>> consecutives(range(1,8),2)
[(1, 2), (2, 3), (3, 4), (4, 5), (5, 6), (6, 7)]
>>> consecutives(range(1,8),3)
[(1, 2, 3), (2, 3, 4), (3, 4, 5), (4, 5, 6), (5, 6, 7)]
>>> consecutives(range(1,8),4)
[(1, 2, 3, 4), (2, 3, 4, 5), (3, 4, 5, 6), (4, 5, 6, 7)]

0

根据您想要迭代子列表还是平面列表:

from itertools import chain
for x in chain(*[ a[i:i+n] for i in xrange(len(a)-n+1) ]):
    print x

或者:

for x in [ a[i:i+n] for i in xrange(len(a)-n+1) ]:
    print x

0

可能不是最好的方法,但仍然有用:

>>> data = [1,2,3,4,5,6,7]
>>> map(None,data[:-1],data[1:])
[(1, 2), (2, 3), (3, 4), (4, 5), (5, 6), (6, 7)]

>>> map(None,data[:-2],data[1:-1],data[2:])
[(1, 2, 3), (2, 3, 4), (3, 4, 5), (4, 5, 6), (5, 6, 7)]

我现在意识到 zip(*args) 和 map(None,*args) 在这个上下文中做的是同样的事情。 - AlwaysBTryin

-4

这是一个相当简单的任务,你可以自己编程完成。我认为没有预先制作好的函数可以做到这一点。

def func(arr,n):
    i = 0
    while i+n < len(arr):
       for range(i,i+n):
          .... make stuff here....
       i = i + 1

目前,我已经有了这个代码,但我正在寻找一个一行代码的解决方案: def loopover(listk, n): l1 = []; s = 0 while(len(listk)): for i in range(0, len(listk)): l1.append(listk[s:n]) s += 1; n += 1; - Process1

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接