例えば、私は持っています:
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
df.reset_index(level=2, drop=True)
Out[29]:
A
1 1 8
3 9
新しいDataFrameインスタンスを作成する必要はありません!インデックスを変更できます。
df.index = df.index.droplevel(2)
df
A
1 1 8
3 9
最後から選択するために、負のインデックスを指定することもできます。
df.index = df.index.droplevel(-1)
インデックスに次のような名前がある場合
_ A
X Y Z
1 1 1 8
3 2 9
_
次に、インデックス名を指定して削除することもできます
df.index = df.index.droplevel(Z)