gpt4 book ai didi

pandas - 对多索引数据框的列进行排序

转载 作者:行者123 更新时间:2023-12-04 12:06:15 24 4
gpt4 key购买 nike

我有一个非常大的多索引数据框,大约有 500 列,每列有 2 个子列。

数据框 df看起来像:

                  B2                  B5             B3
bkt A1 A2 A2 A1 Z2 C1
Date
2019-06-11 0.8 0.2 -6.0 -0.8 -4.1 -0.6
2019-06-12 0.8 0.2 -6.9 -1.6 -5.3 -1.2

df.columns
MultiIndex(levels=[['B2', 'B5', 'B3', .....], ['A1', 'A2' ......]],
labels=[[1, 1, ....], [1, 0, ....]],
names=[None, 'bkt'])

我试图只对列名进行排序并保持每列中的值,以获得以下所需的输出:
                 B2                  B3             B5
bkt A1 A2 C1 Z2 A1 A2
Date
2019-06-11 ..
2019-06-12 ..
..表示来自原始数据帧的值。我只是没有重新输入它们。

设置
df = pd.DataFrame([
[.8, .2, -6., -.8, -4.1, -.6],
[.8, .2, -6.9, -1.6, -5.3, -1.2]
],
pd.date_range('2019-06-11', periods=2, name='Date'),
pd.MultiIndex.from_arrays([
'B2 B2 B5 B5 B3 B3'.split(),
'A1 A2 A2 A1 Z2 C1'.split()
], names=[None, 'bkt'])
)

最佳答案

使用 sort_index 并将其分配回来

df.columns=df.sort_index(axis=1,level=[0,1],ascending=[True,False]).columns
从 piR ,我们不需要创建 df 的副本,只需对列进行修改
df.columns=df.columns.sort_values(ascending=[True, False])

关于pandas - 对多索引数据框的列进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56527988/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com