web-dev-qa-db-ja.com

マルチインデックスのデータフレームからレベルを削除する方法は?

例えば、私は持っています:

In [1]: df = pd.DataFrame([8, 9],
                          index=pd.MultiIndex.from_tuples([(1, 1, 1),
                                                           (1, 3, 2)]),
                          columns=['A'])

In [2] df
Out[2]: 
       A
1 1 1  8
  3 2  9

これよりも最後のレベルをインデックスから削除するより良い方法はありますか?

In [3]: pd.DataFrame(df.values,
                     index=df.index.droplevel(2),
                     columns=df.columns)
Out[3]: 
     A
1 1  8
  3  9
49
Yariv
df.reset_index(level=2, drop=True)
Out[29]: 
     A
1 1  8
  3  9
68
Yariv

新しいDataFrameインスタンスを作成する必要はありません!インデックスを変更できます。

df.index = df.index.droplevel(2)
df

     A
1 1  8
  3  9

最後から選択するために、負のインデックスを指定することもできます。

df.index = df.index.droplevel(-1)
55
Andy Hayden

インデックスに次のような名前がある場合

_       A
X Y Z
1 1 1  8
  3 2  9
_

次に、インデックス名を指定して削除することもできます

df.index = df.index.droplevel(Z)

7