web-dev-qa-db-ja.com

リストの要素のペアを結合する-Python

リストを結合して、次のように1つの長い文字列を作成できることを知っています。

x = ['a', 'b', 'c', 'd']
print ''.join(x)

明らかにこれは出力します:

'abcd'

しかし、私がやろうとしているのは、単にリストの最初と2番目の文字列を結合し、次に3番目と4番目などを結合することです。つまり、上記の例から、代わりに次の出力が得られます。

['ab', 'cd']

これを行う簡単な方法はありますか?また、リスト内の文字列の数は常に偶数ですが、リスト内の文字列の長さと同様に、リスト内の文字列の長さは予測不能であることをおそらく言及する必要があります。したがって、元のリストは次のようになります。

['abcd', 'e', 'fg', 'hijklmn', 'opq', 'r'] 
79
John

ステップでスライス表記を使用できます。

>>> x = "abcdefghijklm"
>>> x[0::2] #0. 2. 4...
'acegikm'
>>> x[1::2] #1. 3. 5 ..
'bdfhjl'
>>> [i+j for i,j in Zip(x[::2], x[1::2])] # Zip makes (0,1),(2,3) ...
['ab', 'cd', 'ef', 'gh', 'ij', 'kl']

リストにも同じロジックが適用されます。単に2つの文字列を追加するだけなので、文字列の長さは関係ありません。

73
utdemir

イテレータを使用します。

リスト理解:

>>> si = iter(['abcd', 'e', 'fg', 'hijklmn', 'opq', 'r'])
>>> [c+next(si, '') for c in si]
['abcde', 'fghijklmn', 'opqr']
  • メモリ使用量が非常に効率的です。
  • Sの正確に1つのトラバーサル

ジェネレーター式:

>>> si = iter(['abcd', 'e', 'fg', 'hijklmn', 'opq', 'r'])
>>> pair_iter = (c+next(si, '') for c in si)
>>> pair_iter # can be used in a for loop
<generator object at 0x4ccaa8>
>>> list(pair_iter) 
['abcde', 'fghijklmn', 'opqr']
  • イテレータとして使用

map、str .__ add __、iterを使用

>>> si = iter(['abcd', 'e', 'fg', 'hijklmn', 'opq', 'r'])
>>> map(str.__add__, si, si)
['abcde', 'fghijklmn', 'opqr']

next(iterator [、default]) はPython 2.6以降で利用可能です

32
kevpie

ただPythonicになるように:-)

>>> x = ['a1sd','23df','aaa','ccc','rrrr', 'ssss', 'e', '']
>>> [x[i] + x[i+1] for i in range(0,len(x),2)]
['a1sd23df', 'aaaccc', 'rrrrssss', 'e']

リストの長さが奇数である場合に警告する場合は、次を試してください。

[x[i] + x[i+1] if not len(x) %2 else 'odd index' for i in range(0,len(x),2)]

幸運のベスト

4
mahmoh

一時リストを作成しない場合:

>>> import itertools
>>> s = 'abcdefgh'
>>> si = iter(s)
>>> [''.join(each) for each in itertools.izip(si, si)]
['ab', 'cd', 'ef', 'gh']

または:

>>> import itertools
>>> s = 'abcdefgh'
>>> si = iter(s)
>>> map(''.join, itertools.izip(si, si))
['ab', 'cd', 'ef', 'gh']
2
pillmuncher

私はRegsが得意ではないので、この方法でやるでしょう。

CODE

t = '1. eat, food\n\
7am\n\
2. brush, teeth\n\
8am\n\
3. crack, eggs\n\
1pm'.splitlines()

print [i+j for i,j in Zip(t[::2],t[1::2])]

出力:

['1. eat, food   7am', '2. brush, teeth   8am', '3. crack, eggs   1pm']  

お役に立てれば :)

1
>>> lst =  ['abcd', 'e', 'fg', 'hijklmn', 'opq', 'r'] 
>>> print [lst[2*i]+lst[2*i+1] for i in range(len(lst)/2)]
['abcde', 'fghijklmn', 'opqr']
1
Andreas Jung