【发布时间】:2020-08-29 01:40:24
【问题描述】:
我有一个这样的数据框输入:
data = {'annee': [2015, 2015],
'medaille': ['Argent', 'Bronze'],
'categorie': ['Punchs', 'Punchs'],
'raisonSociale': ['Héritiers H Clément', 'Héritiers H Clément'],
'Marque': ['Clément', 'Clément'],
'Medaille_Rhum': [{'annee': 2015,
'medaille': 'Argent',
'produit': np.nan,
'Rhum_Name': 'PUNCH CAFE CLEMENT',
'Age': np.nan,
'labels': np.nan},
{'annee': 2015,
'medaille': 'Bronze',
'produit': np.nan,
'Rhum_Name': 'PUNCH PINA COLADA CLEMENT',
'Age': np.nan,
'labels': np.nan}],
'Or': [0, 0],
'Argent': [1, 0],
'Bronze': [0, 1],
'Score': [2, 1]}
df = pd.DataFrame(data)
是的,它是加勒比朗姆酒的数据框
我想使用pivot_table() 在带有分值的列中添加“annee”(例如年份)。我实现了它,但我也希望在 dict 列表中聚合 'Rhum_Name' 列。
我尝试了以下代码:
def ListDict(df):
listDict = []
listDict.extend(df)
return listDict
df_ranking = df_ranking.pivot_table(index=['raisonSociale', 'Marque', 'categorie'],
columns =['annee', 'Medaille_Rhum'],
values = 'Score',
fill_value = '',
aggfunc = {'annee': sum, 'Medaille_Rhum': ListDict},
margins = True,
margins_name = 'Total')
我收到此错误TypeError: unhashable type: 'dict'。我认为这是因为,pivot_table 想要直接遍历字典,但我无法想象如何使它工作。
提前谢谢大家!
【问题讨论】:
标签: python-3.x pandas dataframe json-normalize