假设我pandas.DataFrame在列上有一个分层索引,如下所示:
import pandas as pd
columns = pd.MultiIndex.from_product([list('AB'), list('ab')])
df = pd.DataFrame(np.arange(8).reshape((2,4)), columns=columns)
print df
Run Code Online (Sandbox Code Playgroud)
出[1]:
A B
a b a b
0 0 1 2 3
1 4 5 6 7
Run Code Online (Sandbox Code Playgroud)
我想展平列索引,使其如下所示:
Aa Ab Ba Bb
0 0 1 2 3
1 4 5 6 7
Run Code Online (Sandbox Code Playgroud)
我试过了
def flatten(col):
col.name = ''.join(col.name)
return col
df.apply(f)
Run Code Online (Sandbox Code Playgroud)
但是这只是忽略了新列的修改名称.
piR*_*red 18
set_axisdf.set_axis([f"{x}{y}" for x, y in df.columns], axis=1, inplace=False)
Aa Ab Ba Bb
0 0 1 2 3
1 4 5 6 7
Run Code Online (Sandbox Code Playgroud)
index.mapdf.columns = df.columns.map(''.join)
df
Aa Ab Ba Bb
0 0 1 2 3
1 4 5 6 7
Run Code Online (Sandbox Code Playgroud)
df.columns = df.columns.map(lambda x: ''.join([*map(str, x)]))
df
Aa Ab Ba Bb
0 0 1 2 3
1 4 5 6 7
Run Code Online (Sandbox Code Playgroud)