Объединение пар элементов списка - Python

Я новичок в python (пару недель) и столкнулся с проблемой присоединения к списку. Теперь я знаю, что список можно объединить, чтобы сделать одну длинную строку, как в:

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

Очевидно, это выводит:

'abcd'

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

['ab', 'cd']

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

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

или что угодно. В любом случае, любая помощь вообще была бы весьма признательна, поэтому заранее спасибо.

Ответ 1

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

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

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

Учет списка:

>>> 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']
  • использовать как итератор

Использование карты, 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

Ответ 3

просто для 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

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

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

Ответ 5

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

Ответ 6

Хорошо, я бы сделал это так, потому что я не гожусь с 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']  

Надеюсь, что это поможет:)