替换MultiIndex(pandas)中的值

时间:2015-06-26 11:41:55

标签: python pandas dataframe multi-index

在以下DataFrame中:如何将["x2", "Total"]替换为["x2", "x2"]保留x1原样?

l1           900    902    912     913    916     
l2           ИП ПС  ИП ПС  ИП  ПС  ИП ПС  ИП ПС  
i1    i2                                      
x1    Total  10  6   3  3  10  16   2  9   3  8  
x2    Total   1  0   0  0   0   0   0  0   0  0  

.rename将替换所有"Total"值,而不仅仅是我需要的值。

1 个答案:

答案 0 :(得分:4)

假设您的数据框被称为df,以下代码将通过用修改后的索引替换现有索引来执行您想要的替换。

index = df.index
names = index.names
index = df.index.tolist()[:1]+[('x2','x2')]  
df.index = pd.MultiIndex.from_tuples(index, names = names)

或者您可以直接修改索引的内部级别:

df.index.set_levels([u'Total', u'x2'],level=1,inplace=True)
df.index.set_labels([0, 1],level=1,inplace=True)

您也可以使用level='i2'代替level=1