我有一个dict列表,如下所示:
list=[{u'hello':['001', 3], u'word':['003', 1], u'boy':['002', 2]},
{u'dad':['007', 3], u'mom':['005', 3], u'honey':['002', 2]} ]
我需要的是迭代我的列表,以创建这样的元组列表:
new_list=[('hello','001', 3), ('word','003',1), ('boy','002', 2)
('dad','007',3), ('mom', '005', 3), ('honey','002',2)]
注意!零(‘001’,003’等等)的数字必须考虑为字符串.
有没有人可以帮助我?
解决方法:
你可以使用list comprehension:
new_list = [(key,)+tuple(val) for dic in list for key,val in dic.items()]
在这里,我们迭代列表中的所有dictonaries.对于每个字典,我们迭代它的.items()并提取键和值,然后我们用(key,)val构造一个元组.
值是否为字符串是无关紧要的:列表推导只是复制引用,所以如果原始元素是Foos,它们仍然是Foos.
最后请注意,词典是无序的,所以顺序是不确定的.但是,如果字典d1出现在字典d2之前,则第一个元素的所有元素将被放置在后者的元组之前的列表中.但是没有确定每个单独字典的元组顺序.