我可以使用列表理解语法来创建词典吗?
例如,通过迭代成对的键和值:
d = {... for k, v in zip(keys, values)}
我可以使用列表理解语法来创建词典吗?
例如,通过迭代成对的键和值:
d = {... for k, v in zip(keys, values)}
当前回答
用Python创建具有列表理解的词典我喜欢Python列表理解语法。它也可以用来创建字典吗?例如,通过迭代在成对的键和值上:mydict={(k,v)表示(k,v)在blah blah中}
你要找的是“字典理解”这句话——实际上是:
mydict = {k: v for k, v in iterable}
假设blah-blah-blah是两个元组的可迭代的,那么你就太接近了。让我们创建一些类似的“废话”:
blahs = [('blah0', 'blah'), ('blah1', 'blah'), ('blah2', 'blah'), ('blah3', 'blah')]
听写理解语法:
现在这里的语法是映射部分。这是一个dict理解,而不是set理解(这是你的伪代码所近似的)是冒号,如下所示:
mydict = {k: v for k, v in blahs}
我们看到它是有效的,并且应该保持Python 3.7的插入顺序:
>>> mydict
{'blah0': 'blah', 'blah1': 'blah', 'blah2': 'blah', 'blah3': 'blah'}
在Python 2和3.6版本中,顺序无法保证:
>>> mydict
{'blah0': 'blah', 'blah1': 'blah', 'blah3': 'blah', 'blah2': 'blah'}
添加筛选器:
所有的理解都有一个映射组件和一个过滤组件,可以为任意表达式提供这些组件。
因此,您可以在末尾添加过滤器部件:
>>> mydict = {k: v for k, v in blahs if not int(k[-1]) % 2}
>>> mydict
{'blah0': 'blah', 'blah2': 'blah'}
这里我们只是测试最后一个字符是否可以被2整除,以便在映射键和值之前过滤掉数据。
其他回答
这段代码将使用列表理解为多个列表创建字典,这些列表具有可用于pd.DataFrame()的不同值
#Multiple lists
model=['A', 'B', 'C', 'D']
launched=[1983,1984,1984,1984]
discontinued=[1986, 1985, 1984, 1986]
#Dictionary with list comprehension
keys=['model','launched','discontinued']
vals=[model, launched,discontinued]
data = {key:vals[n] for n, key in enumerate(keys)}
#Convert dict to dataframe
df=pd.DataFrame(data)
display(df)
enumerate将向vals传递n,以使每个键与其列表匹配
添加到@Ekhtiar答案中,若你们想从列表中查找dict,可以使用这个:
names = ['a', 'b', 'd', 'f', 'c']
names_to_id = {v:k for k, v in enumerate(names)}
# {'a': 0, 'b': 1, 'c': 2, 'd': 3, 'f': 4}
或者在极少数情况下,您希望过滤重复项,请使用set first(数字列表中的最佳):
names = ['a', 'b', 'd', 'f', 'd', 'c']
sorted_list = list(set(names))
sorted_list.sort()
names_to_id = {v:k for k, v in enumerate(sorted_list)}
# {'a': 0, 'b': 1, 'c': 2, 'd': 3, 'f': 4}
names = [1,2,5,5,6,2,1]
names_to_id = {v:k for k, v in enumerate(set(names))}
# {1: 0, 2: 1, 5: 2, 6: 3}
在Python 3和Python 2.7+中,字典理解如下所示:
d = {k:v for k, v in iterable}
对于Python 2.6或更早版本,请参见fortran的答案。
要添加到@fortran的答案中,如果您想要遍历键列表key_list以及值列表value_list:
d = dict((key, value) for (key, value) in zip(key_list, value_list))
or
d = {(key, value) for (key, value) in zip(key_list, value_list)}
这种方法使用for循环对给定日期进行迭代。
Syntax: {key: value for (key, value) in data}
Eg:
# create a list comprehension with country and code:
Country_code = [('China', 86), ('USA', 1),
('Ghana', 233), ('Uk', 44)]
# use iterable method to show results
{key: value for (key, value) in Country_code}