无论顺序如何,都删除multiindex中的重复索引

时间:2017-07-28 17:45:18

标签: pandas indexing duplicates series multi-index

使用多索引的简单pd.Series

#create the multiindex and data
mult = pd.MultiIndex.from_product([[1,2,3],[1,2,3]],names=['factor1','factor2'])
data = np.arange(1,4)*np.arange(1,4)[:,np.newaxis]

#create the series
ser = (pd.Series(data.ravel(),
                index=mult,
                name='product')
       .sort_values(ascending=False))

print(ser)
factor1  factor2
3        3          9
         2          6
2        3          6
         2          4
3        1          3
1        3          3
2        1          2
1        2          2
         1          1
Name: product, dtype: int64

如何删除重复索引而不管订单,以便最终系列

factor1  factor2
3        3          9
         2          6
2        2          4
3        1          3
2        1          2
1        1          1
Name: product, dtype: int64

这个想法是2*33*2是相同的因素,所以我们想摆脱一个。我尝试了drop_duplicates,但这消除了任何重复的产品,无论其索引如何(因此1*02*0将被视为重复)。

1 个答案:

答案 0 :(得分:1)

Hacky

ser[~pd.DataFrame(np.sort(np.array(ser.index.tolist()), 1)).duplicated().values]

factor1  factor2
3        3          9
         2          6
2        2          4
3        1          3
2        1          2
1        1          1
Name: product, dtype: int64