如何对DataFrame的索引按指定顺序进行排序?

       有时候,我们需要改变DataFrame的索引的顺序,特别是对分层索引进行unstack()或pivot()操作后,其columns不再按原顺序排列,而是默认按columns内容的升序排列,这不是我们想要的结果,我们希望的是按原来的顺序进行排列。那么这时就会有一个问题,即如何改变其索引顺序呢?特别是按照特定的顺序进行排序,而这个特定顺序我们可以通过一个由索引组成的列表进行指定。具体可以看下图的一个例子。

(图一)

       这个例子中,最初的df的index的顺序是['a','b','c'],但是我们的目的是让其以['c','a','b']排列,当然不能改标索引对应的值。这里的方法是先给df添加和index内容一样的列‘st’,然后最关键的一步是把列'st'的元素转成‘category’类型,这个类型的用处在于可以对这个类型的元素进行任意特定顺序的赋值,图一的代码df['st'].cat.reorder_categories(l,inplace=True)中,就是对‘st’中的元素进行重新指定顺序,这个顺序以参数l指定,l是一个列表,其中对应‘st’元素,l中的顺序就是‘st’中元素对应的新的顺序。指定新顺序后,然后再用df的sort_values()方法,并指定列参数‘st’进行排序,就会按照l指定的顺序重新排列,经过重新设置index,就可以得到新的排列后的df,如图二。

(图二)

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值