pandas 选取行和列数据的方法详解


Posted in Python onAugust 08, 2019

前言

本文介绍在 pandas 中如何读取数据行列的方法。数据由行和列组成,在数据库中,一般行被称作记录 (record),列被称作字段 (field)。回顾一下我们对记录和字段的获取方式:一般情况下,字段根据名称获取,记录根据筛选条件获取。比如获取 student_id 和 studnent_name 两个字段;记录筛选,比如 sales_amount 大于 10000 的所有记录。对于熟悉 SQL 语句的人来说,就是下面的语句:

select student_id, student_name
from exam_scores
where chinese >= 90 and math >= 90

上面的 SQL 语句表示从考试成绩表 (exam_scores) 中,筛选出语文和数学都大于或等于 90 分的所有学生 id 和 name。学习 pandas 数据获取,推荐这种以数据处理的目标为导向的方式,而不是被动的按 pandas 提供的 loc, iloc的语法中,一条条顺序学习。

本篇我们要分析的关于销售数量和金额的一组数据,数据存放在 csv 文件中。示例数据我在 github 上放了一份,方便大家对照练习。

pandas 选取行和列数据的方法详解

选择列

以下两种方法返回 Series 类型:

import pandas as pd
df = pd.read_csv('sample-salesv3.csv')
df.name
# 或者
df['name']

如果需要返回 DataFrame 格式,使用 list 作为参数。为了方便说明,给出在 jupyter notebook 中显示的界面。

pandas 选取行和列数据的方法详解

如果需要选取多列,传给 DataFrame 一个包含列名的 list:

pandas 选取行和列数据的方法详解

选择行

假设我们要筛选 quantity < 0 的所有记录:

pandas 选取行和列数据的方法详解

按多条件筛选的处理方式。假设想筛选 quantity < 0 并且 unit price > 50 的所有记录:

pandas 选取行和列数据的方法详解

代码:

criteria = (df['quantity'] < 0) & (df['unit price'] > 50)
df[criteria].head()

在 pandas 中,AND 条件的运算符为 & ,OR 条件的运算符为 |。假设想筛选所有 quantity > 30 或 unit price > 50 的记录:

pandas 选取行和列数据的方法详解

代码:

criteria = (df['quantity'] > 30) | (df['unit price'] > 50)
df[criteria].head()

基于字符串的记录筛选

如果筛选条件为基于字符串,可以使用用 Series.str.xxx 方法,主要有 startswith, endswith 和 contains等。举一个例子,筛选出所有 name 含有 White 的记录:

pandas 选取行和列数据的方法详解

代码:

criteria = df['name'].str.contains('White')
df[criteria].head()

这里解释一下 pandas 布尔索引 (boolean indexing) 的概念。布尔索引的意思是首先构建一个与 DataFrame 的 index 长度相同的一个 boolean 向量 (boolean vector),这个向量中只包含 True 或者 False,布尔索引是一个 Series。

然后 DataFrame 在筛选的时候,基于 DataFrame 的行索引,当布尔索引相同行索引所在行的 value 为 True 时,DataFrame 的这一行就包含在筛选之中,否则就排除在外。

为了能看得更加清晰,我们把上面的例子用另外一个方法来展示。创建一个新列:is_selected,这一列是一个布尔索引。

df['is_selected'] = df['name'].str.contains('White')

我们看到,is_selected 由 True 和 False 构成。

pandas 选取行和列数据的方法详解

构建了 is_selected 列之后,通过df[df['name'].str.contains('White')] 筛选与下面的语句作用相同:

df[df['is_selected'] == True]

可以把 df['name'].str.contains('White') 这个布尔索引理解为构建了一个新列,然后基于这一列进行筛选。

基于 DateTime 类型的记录筛选

如果列的类型是 DateTime 类型,比如本示例的 date 列。pandas 读取 csv 文件时,date 列是 str 类型,所以我们先将 date 列转换成 datetime 类型,然后基于 pandas 的 Timestamp 类型构建筛选条件。

# 将 date 列转换成 datetime 类型
df['date'] = pd.to_datetime(df['date'])

# 筛选条件为日期大于 2014/4/1
criteria = df['date'] > pd.Timestamp(2014,4,1)
df[criteria].head()

pandas 选取行和列数据的方法详解

同时选择行和列

如果基于本篇所说的模式,同时选择行和列,最简单的方法是组合,比如先基于行构建 DataFrame,然后再基于这个 DataFrame 选取需要的列:

where = df['name'].str.contains('White')
cols = ['name', 'quantity', 'unit price', 'ext price']
df[where][cols].head()

pandas 选取行和列数据的方法详解

参考

Comparison with SQL

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

Python 相关文章推荐
Python爬虫框架Scrapy实战之批量抓取招聘信息
Aug 07 Python
利用Python中unittest实现简单的单元测试实例详解
Jan 09 Python
基于Django的ModelForm组件(详解)
Dec 07 Python
TF-IDF与余弦相似性的应用(一) 自动提取关键词
Dec 21 Python
Python实现朴素贝叶斯分类器的方法详解
Jul 04 Python
Python 生成 -1~1 之间的随机数矩阵方法
Aug 04 Python
python通过TimedRotatingFileHandler按时间切割日志
Jul 17 Python
Python 点击指定位置验证码破解的实现代码
Sep 11 Python
Pandas 解决dataframe的一列进行向下顺移问题
Dec 27 Python
Django ORM 查询表中某列字段值的方法
Apr 30 Python
Python迭代器协议及for循环工作机制详解
Jul 14 Python
解决pytorch-gpu 安装失败的记录
May 24 Python
pandas 对日期类型数据的处理方法详解
Aug 08 #Python
解决Python设置函数调用超时,进程卡住的问题
Aug 08 #Python
Python 根据日志级别打印不同颜色的日志的方法示例
Aug 08 #Python
Python学习笔记之错误和异常及访问错误消息详解
Aug 08 #Python
Python实现直方图均衡基本原理解析
Aug 08 #Python
python获取指定日期范围内的每一天,每个月,每季度的方法
Aug 08 #Python
Python 调用 Outlook 发送邮件过程解析
Aug 08 #Python
You might like
4.与数据库的连接
2006/10/09 PHP
php验证手机号码(支持归属地查询及编码为UTF8)
2013/02/01 PHP
laravel5.4生成验证码的实例讲解
2017/08/05 PHP
PHP 实现base64编码文件上传出现问题详解
2020/09/01 PHP
JavaScript 对象模型 执行模型
2009/12/06 Javascript
jQuery修改CSS伪元素属性的方法
2014/07/30 Javascript
推荐 21 款优秀的高性能 Node.js 开发框架
2014/08/18 Javascript
浅谈js中的闭包
2015/03/16 Javascript
jQuery插件Timelinr 实现时间轴特效
2015/10/04 Javascript
jQuery插件实现无缝滚动特效
2015/11/24 Javascript
js实现prototype扩展的方法(字符串,日期,数组扩展)
2016/01/14 Javascript
详细谈谈javascript的对象
2016/07/31 Javascript
bootstrap datetimepicker日期插件使用方法
2017/01/13 Javascript
jQuery Ajax前后端使用JSON进行交互示例
2017/03/17 Javascript
JavaScript实现父子dom同时绑定两个点击事件,一个用捕获,一个用冒泡时执行顺序的方法
2017/03/30 Javascript
ES6新增的math,Number方法
2017/08/06 Javascript
深入理解JavaScript和TypeScript中的class
2018/04/22 Javascript
vue.js与后台数据交互的实例讲解
2018/08/08 Javascript
vue-cli 脚手架基于Nightwatch的端到端测试环境的过程
2018/09/30 Javascript
ES6 Promise对象的应用实例分析
2019/06/27 Javascript
Python中实现字符串类型与字典类型相互转换的方法
2014/08/18 Python
Python自动化测试ConfigParser模块读写配置文件
2016/08/15 Python
Python3.5 Pandas模块之Series用法实例分析
2019/04/23 Python
Pytorch中index_select() 函数的实现理解
2019/11/19 Python
欧洲最大的美妆零售网站:Feelunique
2017/01/14 全球购物
HSRP的含义以及如何工作
2014/09/10 面试题
银行求职信个人范文
2013/12/16 职场文书
西安交大自主招生自荐信
2014/01/27 职场文书
文明餐桌行动实施方案
2014/02/19 职场文书
关于中国梦的演讲稿
2014/04/23 职场文书
医院信息公开实施方案
2014/05/09 职场文书
服务理念标语
2014/06/18 职场文书
2015年幼儿园元旦亲子活动方案
2014/12/09 职场文书
2016年第29个世界无烟日宣传活动总结
2016/04/06 职场文书
粗暴解决CUDA out of memory的问题
2021/05/22 Python
小程序实现筛子抽奖
2021/05/26 Javascript