Ответы:
В Python 2:
>>> list_a = [1, 2, 3, 4]
>>> list_b = [5, 6, 7, 8]
>>> zip(list_a, list_b)
[(1, 5), (2, 6), (3, 7), (4, 8)]
В Python 3:
>>> list_a = [1, 2, 3, 4]
>>> list_b = [5, 6, 7, 8]
>>> list(zip(list_a, list_b))
[(1, 5), (2, 6), (3, 7), (4, 8)]
s/zip_longest()/izip_longest()
. Переименован в Python 3.x в zip_longest()
.
itertools.product()
делает это
В python 3.0 zip возвращает объект zip. Вы можете получить список из этого, позвонив list(zip(a, b))
.
Вы можете использовать карту лямбда
a = [2,3,4]
b = [5,6,7]
c = map(lambda x,y:(x,y),a,b)
Это также будет работать, если длина оригинальных списков не совпадает
map(None, a,b)
Я знаю, что это старый вопрос, и на него уже был дан ответ, но по какой-то причине я все еще хочу опубликовать это альтернативное решение. Я знаю, что легко узнать, какая встроенная функция делает «магию», которая вам нужна, но не мешает узнать, что вы можете сделать это самостоятельно.
>>> list_1 = ['Ace', 'King']
>>> list_2 = ['Spades', 'Clubs', 'Diamonds']
>>> deck = []
>>> for i in range(max((len(list_1),len(list_2)))):
while True:
try:
card = (list_1[i],list_2[i])
except IndexError:
if len(list_1)>len(list_2):
list_2.append('')
card = (list_1[i],list_2[i])
elif len(list_1)<len(list_2):
list_1.append('')
card = (list_1[i], list_2[i])
continue
deck.append(card)
break
>>>
>>> #and the result should be:
>>> print deck
>>> [('Ace', 'Spades'), ('King', 'Clubs'), ('', 'Diamonds')]
card
в if-elif
не нужны, поэтому у вас есть continue
. (На самом деле, без continue
вас не было бы изменить списки: как ранее упомянутые задания должны быть затем сохранены и стали card = (list_1[i], '')
и card = ('', list_2[1])
соответственно.)
Вывод, который вы показали в постановке задачи - это не кортеж, а список
list_c = [(1,5), (2,6), (3,7), (4,8)]
проверить
type(list_c)
учитывая, что вы хотите получить результат как кортеж из list_a и list_b, сделайте
tuple(zip(list_a,list_b))
<map object at 0x000001F266DCE5C0>
или <zip object at 0x000002629D204C88>
. По крайней мере, решение по поводу map и zip (одного) кажется мне неполным (или слишком сложным) для меня.
Один вариант без использования zip
:
list_c = [(p1, p2) for idx1, p1 in enumerate(list_a) for idx2, p2 in enumerate(list_b) if idx1==idx2]
Если кто-то хочет получить не только кортежи 1-го с 1-м, 2-го с 2-м ... но все возможные комбинации из 2 списков, это будет сделано с
list_d = [(p1, p2) for p1 in list_a for p2 in list_b]
itertools
модуль определяетzip_longest()
метод , который останавливается в конце длинного списка, заполняя недостающие значения , с чем - то вы предоставляете в качестве параметра.