首页 > 解决方案 > 如何将带有元组键的 python 字典转换为 pandas 多索引数据框?

问题描述

我有一个以元组为键的python字典,例如:

dict={('m1',17):4,('m1',12):2,('m1',1):5,('m3',11):4,('m3',17):15}

我想将它转换成这样的熊猫数据框:

m1 17 4
   12 2
   1  5
m3 11 4
   17 15

我尝试了以下方法:

df1=pd.DataFrame(dict)
df2=pd.DataFrame.from_dict(dict)
df3=pd.Series(dict.values(),index=pd.MultiIndex.from_tuples(dict.keys(), names=['site','id'])

但是,没有任何效果。(我还需要命名索引列和值列)

标签: pythonpandasdictionarymulti-index

解决方案


这有效:

from pandas import DataFrame, MultiIndex

d = {('m1', 17): 4, ('m1', 12): 2, ('m1', 1): 5, ('m3', 11): 4, ('m3', 17): 15}
data = DataFrame(
    data={'column_name': list(d.values())}, 
    index=MultiIndex.from_tuples(tuples=d.keys(), names=['site', 'id'])
)

推荐阅读