重複の可能性:
Python でリストをペア (現在、次) として反復する
次のようなリストがあります。
list = [A, B, C, D, E, F, G]
これをグループ化して、次の Python 出力を取得するにはどうすればよいですか
[(A,B), (B,C), (C, D), (D,E), (E,F), (F,G)]
したがって、値は2番目の値でグループ化されますが、順序は保持されます...
重複の可能性:
Python でリストをペア (現在、次) として反復する
次のようなリストがあります。
list = [A, B, C, D, E, F, G]
これをグループ化して、次の Python 出力を取得するにはどうすればよいですか
[(A,B), (B,C), (C, D), (D,E), (E,F), (F,G)]
したがって、値は2番目の値でグループ化されますが、順序は保持されます...
使ってみてくださいzip()
:
zip(lst, lst[1:])
list
また、組み込みのリスト タイプをオーバーライドするため、 name を使用しないでください。
例:
>>> lst = ['A', 'B', 'C', 'D', 'E', 'F', 'G']
>>> zip(lst, lst[1:])
[('A', 'B'), ('B', 'C'), ('C', 'D'), ('D', 'E'), ('E', 'F'), ('F', 'G')]
ジェネレーターまたはその他のワンパス iterables で動作するバージョンの場合、itertools docs のペアワイズ レシピを使用できます。
from itertools import tee, izip
def pairwise(iterable):
"s -> (s0,s1), (s1,s2), (s2, s3), ..."
a, b = tee(iterable)
next(b, None)
return izip(a, b)
>>> a = [1,2,3,4,5]
>>> zip(a, a[1:])
<zip object at 0x7fe6e905ab90>
>>> list(zip(a, a[1:]))
[(1, 2), (2, 3), (3, 4), (4, 5)]
0 から長さ - 1 まで反復するリスト内包表記を使用する
print [(a[i],a[i+1]) for i in range(len(a)-1)]
またはさらに良いことに、zipを使用するだけです
print zip (a,a[1:])