新手在这里,所以很抱歉重复/愚蠢的问题,但我找不到答案。
我正试着把(字典)列表的内容存入一本新字典。
a={}
b=[]
c={"Name":"Claude","Surname":"Verde","Age":"35","City":"Paris"}
b.append(c)
c={"Name":"Jean","Surname":"Claude","Age":"22","City":"Paris"}
b.append(c)
c={"Name":"Sam","Surname":"Smith","Age":"42","City":"London"}
b.append(c)
c={"Name":"James","Surname":"Jones","Age":"44","City":"London"}
b.append(c)
for i in range(len(b)):
if b[i]['City'] == 'Paris':
a["Paris"]=([b[i]])
elif b[i]['City'] == 'London':
a["London"]=([b[i]])
a
结果:
{'Paris': [{'Name': 'Jean',
'Surname': 'Claude',
'Age': '22',
'City': 'Paris'}],
'London': [{'Name': 'James',
'Surname': 'Jones',
'Age': '44',
'City': 'London'}]}
但是,我想要一本包含一个城市所有居民的字典。
上面的代码只存储驻留在列表中的第二个,而不是第一个。
例如,希望得到下面的输出。
我如何才能做到这一点?
非常感谢您的帮助。谢谢
{'Paris': [{'Name': 'Claude',
'Surname': 'Verde',
'Age': '35',
'City': 'Paris'},{'Name': 'Jean',
'Surname': 'Claude',
'Age': '22',
'City': 'Paris'}],
'London': [{'Name': 'Sam',
'Surname': 'Smith,
'Age': '42',
'City': 'London'},{'Name': 'James',
'Surname': 'Jones',
'Age': '44',
'City': 'London'}]}
发布于 2018-08-04 01:32:03
在初始化a时,我会这样处理它:
a = {}
b=[]
c={"Name":"Claude","Surname":"Verde","Age":"35","City":"Paris"}
b.append(c)
c={"Name":"Jean","Surname":"Claude","Age":"22","City":"Paris"}
b.append(c)
c={"Name":"Sam","Surname":"Smith","Age":"42","City":"London"}
b.append(c)
c={"Name":"James","Surname":"Jones","Age":"44","City":"London"}
b.append(c)
for i in range(len(b)):
if b[i]['City'] not in a.keys():
a[b[i]['City']] = []
for i in range(len(b)):
a[b[i]['City']].append(b[i]])
注意:我非常确定你可以像这样组合这些for循环:
for i in range(len(b)):
if b[i]['City'] not in a.keys():
a[b[i]['City']] = []
a[b[i]['City']].append(b[i]])
发布于 2018-08-04 01:37:11
使用itertools.groupby
>>> lst = [
... {"Name":"Claude","Surname":"Verde","Age":"35","City":"Paris"},
... {"Name":"Jean","Surname":"Claude","Age":"22","City":"Paris"},
... {"Name":"Sam","Surname":"Smith","Age":"42","City":"London"},
... {"Name":"James","Surname":"Jones","Age":"44","City":"London"}]
>>>
>>> from itertools import groupby
>>> f = lambda d: d['City']
>>> res = {k:list(v) for k,v in groupby(sorted(lst, key=f), f)}
>>> pprint(res)
{'London': [{'Age': '42', 'City': 'London', 'Name': 'Sam', 'Surname': 'Smith'},
{'Age': '44', 'City': 'London', 'Name': 'James', 'Surname': 'Jones'}],
'Paris': [{'Age': '35', 'City': 'Paris', 'Name': 'Claude', 'Surname': 'Verde'},
{'Age': '22', 'City': 'Paris', 'Name': 'Jean', 'Surname': 'Claude'}]}
发布于 2018-08-04 01:37:45
from itertools import groupby
b = [{'Name': 'Claude', 'Surname': 'Verde', 'Age': '35', 'City': 'Paris'},
{'Name': 'Jean', 'Surname': 'Claude', 'Age': '22', 'City': 'Paris'},
{'Name': 'Sam', 'Surname': 'Smith', 'Age': '42', 'City': 'London'},
{'Name': 'James', 'Surname': 'Jones', 'Age': '44', 'City': 'London'}]
print({k: list(g) for k, g in groupby(b, key=lambda x: x['City'])})
# {'Paris': [{'Name': 'Claude', 'Surname': 'Verde', 'Age': '35', 'City': 'Paris'}, {'Name': 'Jean', 'Surname': 'Claude', 'Age': '22', 'City': 'Paris'}],
# 'London': [{'Name': 'Sam', 'Surname': 'Smith', 'Age': '42', 'City': 'London'}, {'Name': 'James', 'Surname': 'Jones', 'Age': '44', 'City': 'London'}]}
https://stackoverflow.com/questions/51677489
复制相似问题