Объединение пар элементов списка - 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']
Надеюсь, что это поможет:)