如何在 Python 中将两个列表组合成字典? [复制]
Posted
技术标签:
【中文标题】如何在 Python 中将两个列表组合成字典? [复制]【英文标题】:How do I combine two lists into a dictionary in Python? [duplicate] 【发布时间】:2011-11-08 10:34:31 【问题描述】:我有两个长度相同的列表:
[1,2,3,4]
和 [a,b,c,d]
我想创建一个字典,其中有1:a, 2:b, 3:c, 4:d
最好的方法是什么?
【问题讨论】:
*** 的缺点是对 rtfm 的激励更少:docs.python.org/library/stdtypes.html#dict 【参考方案1】:dict(zip([1,2,3,4], [a,b,c,d]))
如果列表很大,您应该使用itertools.izip
。
如果您的键多于值,并且您想为多余的键填写值,您可以使用itertools.izip_longest
。
这里,a
、b
、c
和 d
是变量——它可以正常工作(只要它们被定义),但你可能是指 ['a','b','c','d']
如果你想要它们字符串。
zip
从每个可迭代项中获取第一项并创建一个元组,然后从每个中获取第二项,依此类推。
dict
可以接受一个可迭代的可迭代对象,其中每个内部可迭代对象有两个项目——然后它使用第一个作为键,第二个作为每个项目的值。
【讨论】:
+1 用于指出 OP 在变量名/字符串方面可能存在的错误。 感谢您将我指向izip_longest
,我正是需要这个。
izip() 在 Python3 中被移除,只需使用 zip()
哇 python 太棒了!
堆栈上的答案应该是这样的!您可以轻松复制顶部的清晰示例,指向正确方向的简短说明,了解更多信息的链接,并且很简短,您可以在一页中找到完整的答案。【参考方案2】:
>>> dict(zip([1, 2, 3, 4], ['a', 'b', 'c', 'd']))
1: 'a', 2: 'b', 3: 'c', 4: 'd'
如果它们的大小不同,zip
将截断较长的那个。
【讨论】:
docs.python.org/library/stdtypes.html#dict 参考【参考方案3】:dict(zip([1,2,3,4], ['a', 'b', 'c', 'd']))
http://docs.python.org/library/functions.html
【讨论】:
【参考方案4】:我不知道最好的(最简单的?最快的?最易读的?),但一种方法是:
dict(zip([1, 2, 3, 4], [a, b, c, d]))
【讨论】:
【参考方案5】:我发现自己需要创建一个包含三个列表(纬度、经度和一个值)的字典,并使用以下方法:
> lat = [45.3,56.2,23.4,60.4]
> lon = [134.6,128.7,111.9,75.8]
> val = [3,6,2,5]
> dict(zip(zip(lat,lon),val))
(56.2, 128.7): 6, (60.4, 75.8): 5, (23.4, 111.9): 2, (45.3, 134.6): 3
或类似上面的例子:
> list1 = [1,2,3,4]
> list2 = [1,2,3,4]
> list3 = ['a','b','c','d']
> dict(zip(zip(list1,list2),list3))
(3, 3): 'c', (4, 4): 'd', (1, 1): 'a', (2, 2): 'b'
注意:字典是“无序”的,但如果您想将其视为“排序”,如果您想按键排序,请参考THIS问题,或@987654322 @问你是否想按值排序。
【讨论】:
【参考方案6】:如果第一个列表中有重复的键映射到第二个列表中的不同值,例如一对多的关系,但您需要组合或添加这些值,而不是更新,您可以这样做这个:
i = iter(["a", "a", "b", "c", "b"])
j = iter([1,2,3,4,5])
k = list(zip(i, j))
for (x,y) in k:
if x in d:
d[x] = d[x] + y #or whatever your function needs to be to combine them
else:
d[x] = y
在那个例子中,d == 'a': 3, 'c': 4, 'b': 8
【讨论】:
以上是关于如何在 Python 中将两个列表组合成字典? [复制]的主要内容,如果未能解决你的问题,请参考以下文章
如何在spark(Python)中将两个rdd组合成on rdd
如何在 Oracle 中将多行组合成逗号分隔的列表? [复制]
如何在 SQL Server 2005 中将多行组合成以逗号分隔的列表?