我输入的数据如下
[{'s1': 'INT', 's2': 'INT'}, {'s1': 'TINYINT', 's2': 'TINYINT'}, {'s1': 'SMALLINT', 's2': 'SMALLINT'}, {'s1': 'BIGINT', 's2': 'BIGINT'}, {'s1': 'BIT', 's2': 'VARCHAR(10)'}, {'s1': 'FLOAT', 's2': 'FLOAT'}]
并希望输出如下。
{'INT':'INT', 'TINYINT': 'TINYINT', 'SMALLINT': 'SMALLINT', 'BIGINT': 'BIGINT', 'BIT': 'VARCHAR(10)', 'FLOAT': 'FLOAT'}
我已经完成了以下SO问题,但没有运气。
How do I merge a list of dicts into a single dict?
请提出任何建议。
答案 0 :(得分:3)
您可以使用简单的词典理解:
a = [{'s1': 'INT', 's2': 'INT'},
{'s1': 'TINYINT', 's2': 'TINYINT'},
{'s1': 'SMALLINT', 's2': 'SMALLINT'},
{'s1': 'BIGINT', 's2': 'BIGINT'},
{'s1': 'BIT', 's2': 'VARCHAR(10)'},
{'s1': 'FLOAT', 's2': 'FLOAT'}]
d = {x['s1']: x['s2'] for x in a}
print(d)
输出:
{'BIGINT': 'BIGINT',
'BIT': 'VARCHAR(10)',
'FLOAT': 'FLOAT',
'INT': 'INT',
'SMALLINT': 'SMALLINT',
'TINYINT': 'TINYINT'}
答案 1 :(得分:3)
这是一种方法。
s = [{'s1': 'INT', 's2': 'INT'}, {'s1': 'TINYINT', 's2': 'TINYINT'}, {'s1': 'SMALLINT', 's2': 'SMALLINT'}, {'s1': 'BIGINT', 's2': 'BIGINT'}, {'s1': 'BIT', 's2': 'VARCHAR(10)'}, {'s1': 'FLOAT', 's2': 'FLOAT'}]
print(dict((i["s1"], i["s2"]) for i in s))
<强>输出:强>
{'SMALLINT': 'SMALLINT', 'INT': 'INT', 'FLOAT': 'FLOAT', 'TINYINT': 'TINYINT', 'BIGINT': 'BIGINT', 'BIT': 'VARCHAR(10)'}
答案 2 :(得分:1)
这是一个简单的python代码,它提供了问题中提出的相同输出。
dict_list = [{'s1': 'INT', 's2': 'INT'}, {'s1': 'TINYINT', 's2': 'TINYINT'}, {'s1': 'SMALLINT', 's2': 'SMALLINT'}, {'s1': 'BIGINT', 's2': 'BIGINT'}, {'s1': 'BIT', 's2': 'VARCHAR(10)'}, {'s1': 'FLOAT', 's2': 'FLOAT'}]
new_dict = {}
for dl in dict_list:
new_dict[dl['s1']] = dl['s2']
print(new_dict)
我们通过运行此代码段获得以下输出
{'SMALLINT': 'SMALLINT', 'INT': 'INT', 'FLOAT': 'FLOAT', 'TINYINT': 'TINYINT', 'BIGINT': 'BIGINT', 'BIT': 'VARCHAR(10)'}
答案 3 :(得分:-1)
虽然 keyur Pordars答案会解决,但是使用python 3.6使用dict理解使其更强大 泛型 。
b = {list(k.values())[0]:list(k.values())[1] for k in a}
# k.values() return the **view** of the values (not a list in python 3) of
# each dict item in the list and then we wrap it into a list a and index it.
print(b) # print the output
# OUTPUT {'INT': 'INT', 'TINYINT': 'TINYINT', 'SMALLINT': 'SMALLINT', 'BIGINT': 'BIGINT', 'BIT': 'VARCHAR(10)', 'FLOAT': 'FLOAT'}