Объединение пар элементов списка - Python - PullRequest
78 голосов
/ 02 мая 2011

Я знаю, что список можно объединить, чтобы сделать одну длинную строку, как в:

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

Очевидно, что это приведет к:

'abcd'

Однако, что я пытаюсь сделатьпросто присоедините первую и вторую строки в списке, затем присоедините третью и четвертую и так далее.Вкратце, из приведенного выше примера вместо этого получим результат:

['ab', 'cd']

Есть ли простой способ сделать это?Я, вероятно, должен также упомянуть, что длина строк в списке будет непредсказуемой, как и количество строк в списке, хотя количество строк всегда будет четным.Таким образом, оригинальный список также может быть:

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

Ответы [ 6 ]

73 голосов
/ 02 мая 2011

Вы можете использовать обозначение среза с шагами:

>>> 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']

Та же логика применима и к спискам. Длина строки не имеет значения, потому что вы просто добавляете две строки вместе.

31 голосов
/ 02 мая 2011

Используйте итератор.

Понимание списка:

>>> si = iter(['abcd', 'e', 'fg', 'hijklmn', 'opq', 'r'])
>>> [c+next(si, '') for c in si]
['abcde', 'fghijklmn', 'opqr']
  • Очень эффективно для использования памяти.
  • Ровно один обход s

Выражение генератора:

>>> 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 (итератор [, по умолчанию]) доступно начиная с Python 2.6

4 голосов
/ 07 апреля 2014

только для того, чтобы быть питоническим: -)

>>> 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)]

Best of Luck

2 голосов
/ 02 мая 2011

Без построения временных списков:

>>> 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']
1 голос
/ 16 ноября 2013

Ну, я бы сделал это так, потому что мне плохо с Regs ..

КОД

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 голос
/ 02 мая 2011
>>> 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']
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...