我有一个包含以下列的pandas.Dataframe
:
a_1 ab_1 ac_1 a_2 ab_2 ac_2
2 3 4 5 6 7
如何将其转换为以下内容?
a ab ac
2 3 4
5 6 7
我试图使用pandas melt来从宽格式转换为长格式,但不确定语法.
解决方法:
您可以将split
用于MultiIndex,然后在stack
之前重新整形,最后使用reset_index
删除MultiIndex:
df.columns = df.columns.str.split('_', expand=True)
df = df.stack().reset_index(drop=True)
print (df)
a ab ac
0 2 3 4
1 5 6 7
df = df.stack().reset_index(level=0, drop=True)
print (df)
a ab ac
1 2 3 4
2 5 6 7