在pandas多重索引multiIndex中选定指定索引的行方法


Posted in Python onNovember 16, 2018

在multiIndex中选定指定索引的行

我们在用pandas类似groupby来使用多重index时,有时想要对多个level中的某个index对应的行进行操作,就需要在dataframe中找到该index对应的行,在单层index中我们可以方便的使用df.loc[index]来选择,在多重Index中我们可以利用的类似的思路,然而其中也有一些小坑,记录如下。

1 index为有序的

1.1 创建测试数据

首先创建一个dataframe数据

df = pd.DataFrame({'class':['A','A','A','B','B','B','C','C'],
   'id':['a','b','c','a','b','c','a','b'],
   'value':[1,2,3,4,5,6,7,8]})

df中内容如下图:

在pandas多重索引multiIndex中选定指定索引的行方法

1.2 设置multiIndex

通过set_index设为多重索引

df = df.set_index(['class','id'])

设置索引后效果:

在pandas多重索引multiIndex中选定指定索引的行方法

1.3 切片筛选index

这里同样使用loc定位

df.loc[('A',slice(None)),:]

各参数的解释如下:

loc[(a,b),c]中第一个参数元组为索引内容,a为level0索引对应的内容,b为level1索引对应的内容

因为df是一个dataframe,所以要用c来指定列

这里‘A',指选择class中的A类

slice(None), 是Python中的切片操作,这里用来选择任意的id,要注意!不能使用‘:'来指定任意index

‘:',用来指定dataframe任意的列

执行后的结果如下:

在pandas多重索引multiIndex中选定指定索引的行方法

同样,如果想只保留id中的'a',则可以使用:

df.loc[(slice(None),'a'),:]

2 index无序

前面的例子对应的index列为数字或字母,是有序的,接下来我们看看index列为中文的情况。

2.1 创建无序测试数据

df2 = pd.DataFrame({'课程':['语文','语文','数学','数学'],'得分':['最高','最低','最高','最低'],'分值':[90,50,100,60]})
df2 = df2.set_index(['课程','得分'])

在pandas多重索引multiIndex中选定指定索引的行方法

2.2 尝试切片选择index

df2.loc[('语文',slice(None)),:]

我们进行同样的操作,这时会发现提示出错:

UnsortedIndexError: 'MultiIndex Slicing requires the index to be fully lexsorted tuple len (2), lexsort depth (0)'

这是因为此时的index无法进行排序,在pandas文档中提到:Furthermore if you try to index something that is not fully lexsorted, this can raise:

我们可以通过 df2.index.is_lexsorted()来检查index是否有序,

In[1]: df2.index.is_lexsorted()
out[1]: False

接下来,我们尝试对Index进行排序。(排序时要在level里指定index名)

2.3 对index排序后切片选择index

df2 = df2.sort_index(level='课程')
df2.loc[('语文',slice(None)),:]

在pandas多重索引multiIndex中选定指定索引的行方法

得到了我们想要的结果。

参考文献:pandas-docs-MultiIndex / Advanced Indexing

以上这篇在pandas多重索引multiIndex中选定指定索引的行方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
安装dbus-python的简要教程
May 05 Python
python 写入csv乱码问题解决方法
Oct 23 Python
对Python 简单串口收发GUI界面的实例详解
Jun 12 Python
Python 的字典(Dict)是如何存储的
Jul 05 Python
Python3从零开始搭建一个语音对话机器人的实现
Aug 23 Python
python实现智能语音天气预报
Dec 02 Python
django的403/404/500错误自定义页面的配置方式
May 21 Python
Python调用飞书发送消息的示例
Nov 10 Python
利用python 下载bilibili视频
Nov 13 Python
Pyqt5将多个类组合在一个界面显示的完整示例
Sep 04 Python
Python面向对象编程之类的概念
Nov 01 Python
python标准库ElementTree处理xml
May 20 Python
对Pandas MultiIndex(多重索引)详解
Nov 16 #Python
一百行python代码将图片转成字符画
Feb 19 #Python
Pandas GroupBy对象 索引与迭代方法
Nov 16 #Python
python实现指定字符串补全空格、前面填充0的方法
Nov 16 #Python
pandas 透视表中文字段排序方法
Nov 16 #Python
用Python实现数据的透视表的方法
Nov 16 #Python
pandas pivot_table() 按日期分多列数据的方法
Nov 16 #Python
You might like
PHP通过header实现文本文件下载的代码
2010/08/08 PHP
PHP语言中global和$GLOBALS[]的分析 之二
2012/02/02 PHP
PHP二维数组排序的3种方法和自定义函数分享
2014/04/09 PHP
php读取目录及子目录下所有文件名的方法
2014/10/20 PHP
php快速导入大量数据的实例方法
2019/09/23 PHP
分享几个超级震憾的图片特效
2012/01/08 Javascript
jquery左右滚动焦点图banner图片鼠标经过显示上下页按钮
2013/10/11 Javascript
jquery iframe操作详细解析
2013/11/20 Javascript
javascript写的一个模拟阅读小说的程序
2014/04/04 Javascript
禁用Enter键表单自动提交实现代码
2014/05/22 Javascript
jquery获取html元素的绝对位置和相对位置的方法
2014/06/20 Javascript
jQuery DOM插入节点操作指南
2015/03/03 Javascript
AngularJs Understanding the Controller Component
2016/09/02 Javascript
jQuery动态改变多行文本框高度的方法
2016/09/07 Javascript
ajax异步请求详解
2017/01/06 Javascript
jquery根据name取得select选中的值实例(超简单)
2018/01/25 jQuery
Vue.js中的computed工作原理
2018/03/22 Javascript
vue-cli构建项目下使用微信分享功能
2018/05/28 Javascript
vue 纯js监听滚动条到底部的实例讲解
2018/09/03 Javascript
node.js实现带进度条的多文件上传
2020/03/27 Javascript
node使用request请求的方法
2019/12/20 Javascript
使用typescript改造koa开发框架的实现
2020/02/04 Javascript
Javascript Symbol原理及使用方法解析
2020/10/22 Javascript
Python中的集合类型知识讲解
2015/08/19 Python
Python面向对象程序设计之继承与多继承用法分析
2018/07/13 Python
Python实现将数据写入netCDF4中的方法示例
2018/08/30 Python
详解Python连接MySQL数据库的多种方式
2019/04/16 Python
python 实现将文件或文件夹用相对路径打包为 tar.gz 文件的方法
2019/06/10 Python
python脚本调用iftop 统计业务应用流量的思路详解
2019/10/11 Python
Python3.7 读取 mp3 音频文件生成波形图效果
2019/11/05 Python
在 Python 中使用 7zip 备份文件的操作
2020/12/11 Python
医院院务公开实施方案
2014/05/03 职场文书
党干部专题民主生活会对照检查材料思想汇报
2014/10/06 职场文书
销售经理工作失职检讨书
2014/10/24 职场文书
2015年社区工作总结
2015/04/08 职场文书
选对餐饮营销策略,营业额才会上涨
2019/08/27 职场文书