如何将列表合并到元组列表中?

rub*_*eet 279 python merge tuples list

什么是Pythonic方法来实现以下目标?

# Original lists:

list_a = [1, 2, 3, 4]
list_b = [5, 6, 7, 8]

# List of tuples from 'list_a' and 'list_b':

list_c = [(1,5), (2,6), (3,7), (4,8)]
Run Code Online (Sandbox Code Playgroud)

每个成员list_c都是一个元组,其第一个成员来自list_a,而第二个来自list_b.

YOU*_*YOU 400

>>> 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)]
Run Code Online (Sandbox Code Playgroud)

  • 你必须知道zip函数在最短列表的末尾停止,这可能并不总是你想要的.`itertools`模块定义了一个`zip_longest()`方法,该方法在最长列表的末尾停止,用您提供的参数填充缺失值. (74认同)
  • @Adrien:为您的适用评论欢呼.对于Python 2.x,`s/zip_longest()/ izip_longest()`.在Python 3.x中重命名为`zip_longest()`. (5认同)
  • @MonaJalal:不,那不是配对,那就是创建列表的*产品*.`itertools.product()`做到了. (3认同)
  • 注意,至少在python3.6 zip中不返回列表.所以你需要列表(zip(list_a,list_b)) (2认同)

Lod*_*ijk 139

在python 3.0中,zip返回一个zip对象.您可以通过致电获取列表list(zip(a, b)).

  • 这可能是微不足道的,但请注意,直接在for循环中使用它会为您提供一个生成器,该生成器在使用一次后将被耗尽。如果要更频繁地使用它,请保存到变量中 (3认同)

Dar*_*ght 13

您可以使用map lambda

a = [2,3,4]
b = [5,6,7]
c = map(lambda x,y:(x,y),a,b)
Run Code Online (Sandbox Code Playgroud)

如果原始列表的长度不匹配,这也将起作用

  • 如果你使用的是python3,那么c就不会是一个列表,它将成为一个地图对象,使用lambda的效率将远低于压缩,如果你有不同的长度列表并且想要处理那么你会使用izip_longest/zip_longest (3认同)

Miz*_*zor 8

你正在寻找内置功能zip.


小智 6

我不确定这是否是pythonic方式,但是如果两个列表具有相同数量的元素,这似乎很简单:

list_a = [1, 2, 3, 4]

list_b = [5, 6, 7, 8]

list_c=[(list_a[i],list_b[i]) for i in range(0,len(list_a))]
Run Code Online (Sandbox Code Playgroud)


Kru*_*ger 5

我知道这是一个老问题,已经得到了解答,但出于某种原因,我仍然想发布这个替代解决方案.我知道很容易找出你需要的"神奇"内置函数,但知道你可以自己做它并不会有害.

>>> 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')]
Run Code Online (Sandbox Code Playgroud)

  • 更改其中一个输入列表(如果它们的长度不同)不是一个很好的副作用.此外,不需要在`if-elif`中对"card"的两个赋值,这就是为什么你有'continue`的原因.(事实上​​,如果没有`继续`,你就不必改变列表:之前提到的两个赋值都应该保存并变成`card =(list_1 [i],'')`和`card =('', list_2 [1])`.分别.) (2认同)

cyb*_*org 5

您在问题陈述中显示的输出不是元组而是列表

list_c = [(1,5), (2,6), (3,7), (4,8)]
Run Code Online (Sandbox Code Playgroud)

检查

type(list_c)
Run Code Online (Sandbox Code Playgroud)

考虑到你想把结果作为list_a和list_b的元组,做

tuple(zip(list_a,list_b)) 
Run Code Online (Sandbox Code Playgroud)