详解pandas DataFrame的查询方法(loc,iloc,at,iat,ix的用法和区别)


Posted in Python onAugust 02, 2019

在操作DataFrame时,肯定会经常用到loc,iloc,at等函数,各个函数看起来差不多,但是还是有很多区别的,我们一起来看下吧。

首先,还是列出一个我们用的DataFrame,注意index一列,如下:

详解pandas DataFrame的查询方法(loc,iloc,at,iat,ix的用法和区别)

接下来,介绍下各个函数的用法:

1、loc函数

愿意看官方文档的,请戳这里,这里一般最权威。
loc函数是基于“标签”选择数据的,但是也可以接受一个boolean的array,对于每个用法,我们从参数方面来一一举例:

1.1 单个label

接受一个“标签”(label)参数,返回一个Series,例如下面这个例子收一个标签,返回通过这个标签定位的行的值,注意这里是通过标签定位,而不是通过中括号中的数字定位第几行,之后我们通过对比iloc函数时还会细说。

test_dict_df.loc[1] #return the row with name 'Bob'
test_dict_df.loc[7] #return the row with name 'Time' important!!!
# type(test_dict_df.loc[1]) #pandas.core.series.Series

1.2 一个label的array

如果键入一个标签的array,那么就返回一个对应的DataFrame:

test_dict_df.loc[[1,2,4]]

结果如下:

详解pandas DataFrame的查询方法(loc,iloc,at,iat,ix的用法和区别)

1.3 加入一个切片array

test_dict_df.loc[[1:4]]

结果如下:

详解pandas DataFrame的查询方法(loc,iloc,at,iat,ix的用法和区别)

1.4 行标签,列标签

通过在中括号中加入行标签和列标签来定位一个cell,相当于坐标的定位:

test_dict_df.loc[1,'english'] #result:94

1.5 行标签或者列标签是切片array

test_dict_df.loc[1:4,'english']
# test_dict_df.loc[1:4,'english':'math']

1.6 还可以接受条件,进行选择

例如我们选择英语成绩超过90的所有行:

test_dict_df.loc[test_dict_df['english']>90]

详解pandas DataFrame的查询方法(loc,iloc,at,iat,ix的用法和区别)

当然,也可以再条件选择后,再加入列选择,列选择的时候可以单列,也可以是切片数组,通过上面的介绍这里就可以灵活处理:

test_dict_df.loc[test_dict_df['english']>90,'english'] #single label
test_dict_df.loc[test_dict_df['english']>90,'english':'name'] #slice array
test_dict_df.loc[test_dict_df['english']>90,['english','name']] #label array

1.7 接受一个boolean的array

可以接受一个boolean的array,相当于按照这个表的真假按照位置的顺序选择值

test_dict_df.loc[[True,False,False,True]]

loc还有很多用法,这里先介绍到这里吧,当然如果你的DataFrame是复合的行或者复合列,写法也是不同的,具体就可以查阅官方文档了!

2、iloc函数

官方文档戳这里。

iloc函数与loc函数不同的是,它接受的是一个数字,代表着要选择数据的位置:

test_dict_df.iloc[6]

这代表我们选择的是第6行,而不是index为6的那一行。当然,也可以接受一个boolean的array,相当于按照这个表的真假按照位置的顺序选择值:

test_dict_df.iloc[[True,False,False,True]]

这里iloc也可以接受切片array:

# test_dict_df.iloc[1:2]
test_dict_df.iloc[[1,2,4]]

3、ix函数(0.20.0版本后已经弃用)

ix就是一种混合索引,字符串的标签和证书的数据索引都可以作为合法输入,其实相当于loc和iloc的一个混合方法:

test_dict_df.ix['Alice']
test_dict_df.ix[1]

上述两种方法都能得到值,这里我们就不追究这个函数具体是怎样的检索顺序或者工作原理了。因为官方给出的是从pandas0.20.0之后,ix函数已经被弃用。其实在使用的时候,ix函数虽然方便,但是的确有时候会显得比较混乱,所以我们之后也尽量少用这个函数吧,还是按照官方大佬的指导。

4、at函数

at是用来选择单个值的,此时用法类似于loc:

test_dict_df.at[1,'english']
test_dict_df.loc[1,'english']

以上两种方法都能选择到,label为1,列为'english'的那个值,但是据说at速度要快,这点我没有考证过。

5、iat函数

iat函数相对于at函数,就相当于iloc相对于loc函数。iat也只能选择一个值。只不过是用索引位置来选择,注意:行列都是索引位置来选择,从0开始数。

# test_dict_df.iat[1,'english'] #error!!!
test_dict_df.iat[2,2] #right!!!

6、概括一下

最后我们概括一下:

1、 loc和iloc函数都是用来选择某行的,iloc与loc的不同是:iloc是按照行索引所在的位置来选取数据,参数只能是整数。而loc是按照索引名称来选取数据,参数类型依索引类型而定;

2、 at和iat函数是只能选择某个位置的值,iat是按照行索引和列索引的位置来选取数据的。而at是按照行索引和列索引来选取数据;

3、 loc和iloc函数的功能包含at和iat函数的功能。

相应的代码连接:github代码

先写到这里,如有新的再补充。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python爬虫常用的模块分析
Aug 29 Python
Python中collections模块的基本使用教程
Dec 07 Python
python调试神器PySnooper的使用
Jul 03 Python
Python利用matplotlib做图中图及次坐标轴的实例
Jul 08 Python
Python Django的安装配置教程图文详解
Jul 17 Python
Python数据可视化:箱线图多种库画法
Nov 06 Python
python加密解密库cryptography使用openSSL生成的密匙加密解密
Feb 11 Python
python字符串拼接+和join的区别详解
Dec 03 Python
Python实现小黑屋游戏的完整实例
Jan 06 Python
Python+OpenCV实现在图像上绘制矩形
Mar 21 Python
浅析Python OpenCV三种滤镜效果
Apr 11 Python
利用Python实时获取steam特惠游戏数据
Jun 25 Python
pandas DataFrame创建方法的方式
Aug 02 #Python
django项目环境搭建及在虚拟机本地创建django项目的教程
Aug 02 #Python
Django缓存系统实现过程解析
Aug 02 #Python
tensor和numpy的互相转换的实现示例
Aug 02 #Python
Django文件存储 自己定制存储系统解析
Aug 02 #Python
使用pycharm在本地开发并实时同步到服务器
Aug 02 #Python
Django文件存储 默认存储系统解析
Aug 02 #Python
You might like
PHP+jQuery+Ajax实现分页效果 jPaginate插件的应用
2015/10/09 PHP
PHP检查网站是否宕机的方法示例
2017/07/24 PHP
Expandable "Detail" Table Rows
2007/08/29 Javascript
jQuery的实现原理的模拟代码 -4 重要的扩展函数 extend
2010/08/03 Javascript
JS中令人发指的valueOf方法介绍
2013/02/22 Javascript
js实时获取系统当前时间实例代码
2013/06/28 Javascript
JS模拟自动点击的简单实例
2013/08/08 Javascript
Javascript中的apply()方法浅析
2015/03/15 Javascript
js实现鼠标滑过文字链接色彩变化的效果
2015/05/06 Javascript
JS简单限制textarea内输入字符数量的方法
2015/10/14 Javascript
localStorage实现便签小程序
2016/11/28 Javascript
使用node.js对音视频文件加密的实例代码
2017/08/30 Javascript
vue+axios+mock.js环境搭建的方法步骤
2018/08/28 Javascript
vue中使用v-model完成组件间的通信
2019/08/22 Javascript
Javascript Dom元素获取和添加详解
2019/09/24 Javascript
js实现图片无缝循环轮播
2019/10/28 Javascript
通过javascript实现扫雷游戏代码实例
2020/02/09 Javascript
JavaScript实现移动端带transition动画的轮播效果
2020/03/24 Javascript
详解微信小程序(Taro)手动埋点和自动埋点的实现
2021/03/02 Javascript
python实现telnet客户端的方法
2015/04/15 Python
Hadoop中的Python框架的使用指南
2015/04/22 Python
python爬虫入门教程--HTML文本的解析库BeautifulSoup(四)
2017/05/25 Python
python实现生成字符串大小写字母和数字的各种组合
2019/01/01 Python
pytorch实现特殊的Module--Sqeuential三种写法
2020/01/15 Python
Python 通过爬虫实现GitHub网页的模拟登录的示例代码
2020/08/17 Python
整理HTML5移动端开发的常用触摸事件
2016/04/15 HTML / CSS
预备党员思想汇报
2014/01/08 职场文书
黄河的主人教学反思
2014/02/07 职场文书
IT工程师岗位职责
2014/07/04 职场文书
俞敏洪一分钟演讲稿
2014/08/26 职场文书
2014年重阳节敬老活动方案
2014/09/16 职场文书
领导班子作风建设剖析材料
2014/10/11 职场文书
小学四年级班务总结该怎么写?
2019/08/16 职场文书
Java中常用解析工具jackson及fastjson的使用
2021/06/28 Java/Android
教你使用Jenkins集成Harbor自动发布镜像
2022/04/03 Servers
Redis Lua脚本实现ip限流示例
2022/07/15 Redis