我在一个数据框中有一列,每一行是一个列表,它是许多具有相同键的词典的集合。我想把字典里所有的东西都从同一把钥匙里取出来。
我有这个清单:
s = [{'category': 'Public',
'name': 'Newspaper',
'person': 'A'},
{'category': 'Music',
'name': 'Andre',
'person': 'B'},
{'category': 'Music',
'name': 'Indian',
'person': 'A'},
{'category': 'Artist',
'name': 'Rihe',
'person': 'D'},
{'category': 'Interest',
'name': 'Sport',
'person': 'B'}]
我试过使用循环和itemgetter,但由于数据量大,这需要很多时间。我在找一个更有效的方法来做这件事。
from operator import itemgetter
category = []
name_page = []
getter_category = itemgetter('category')
getter_name = itemgetter('name')
for element in s:
name_page.append(getter_name(element))
category.append(getter_category(element))
我想要更有效的方法,比如:
s['category'] = ['Public','Music','Music','Artist','Interest']
s['name'] = ['Newspaper','Andre','Indian','Rihe','Sport']
s['person'] = ['A','B','A','D','B']
最佳答案
使用defaultdict
fromcollections
from collections import defaultdict
o = defaultdict(list)
for ss in s:
for k, v in ss.items():
o[k] += [v]
print(dict(o))
Out[7]:
{'category': ['Public', 'Music', 'Music', 'Artist', 'Interest'],
'name': ['Newspaper', 'Andre', 'Indian', 'Rihe', 'Sport'],
'person': ['A', 'B', 'A', 'D', 'B']}
关于python - 如何在python中的列表中访问字典中的项目?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/56140507/