将Pandas数据帧透视到分层列/更改列层次结构

2024-06-02 08:02:50 发布

您现在位置:Python中文网/ 问答频道 /正文

我想要一个数据帧,比如:

       dim1   Value_V     Value_y   instance
0      A_1     50.000000        0   instance200
1      A_2   6500.000000        1   instance200
2      A_3     50.000000        0   instance200
3      A_4   4305.922313        1   instance200

到一个具有如下层次结构列的数据帧中:

^{pr2}$

我试过df = df.pivot(index = "instance", columns = "dim1"),但它只能给我一个这样的帧:

              Value_V               Value_y                              
              A_1   A_2   A_3 ....  A_1  A_2  A_3 ....
instance200   50    6500  50        0    1    0

如何更改列的层次结构?在


Tags: columns数据instancedfindex层次结构valuepivot
2条回答

您需要的是对级别重新排序,然后对列进行排序,如下所示:

import pandas as pd

df = pd.read_clipboard()

df
Out[8]:
dim1    Value_V Value_y instance
0   A_1 50.000000   0   instance200
1   A_2 6500.000000 1   instance200
2   A_3 50.000000   0   instance200
3   A_4 4305.922313 1   instance200
In [9]:

df.pivot('instance', 'dim1').reorder_levels([1, 0], axis=1).sort(axis=1)
Out[9]:
dim1        A_1             A_2             A_3             A_4
            Value_V Value_y Value_V Value_y Value_V Value_y Value_V Value_y
instance                                
instance200 50      0       6500    1       50      0       4305.922313 1

我自己想出来了:

df = df.swaplevel(0,1,axis = 1).sort(axis = 1)

会的

相关问题 更多 >