数据分析实践入门(二):数据选择——AIU人工智能学院-经管之家官网!

人大经济论坛-经管之家 收藏本站
您当前的位置> 数据>>

数据分析

>>

数据分析实践入门(二):数据选择——AIU人工智能学院

数据分析实践入门(二):数据选择——AIU人工智能学院

发布:AIU人工智能学院 | 分类:数据分析

关于本站

人大经济论坛-经管之家:分享大学、考研、论文、会计、留学、数据、经济学、金融学、管理学、统计学、博弈论、统计年鉴、行业分析包括等相关资源。
经管之家是国内活跃的在线教育咨询平台!

获取电子版《CDA一级教材》

完整电子版已上线CDA网校,累计已有10万+在读~ 教材严格按考试大纲编写,适合CDA考生备考,也适合业务及数据分析岗位的从业者提升自我。

完整电子版已上线CDA网校,累计已有10万+在读~ 教材严格按考试大纲编写,适合CDA考生备考,也适合业务及数据分析岗位的从业者提升自我。

AIU人工智能学院:数据科学、人工智能从业者的在线大学。数据科学(Python/R/Julia)数据分析、机器学习、深度学习作者|CDA数据分析师之前是把所有的菜品都洗好并放在不同的盛放的容器里。现在要进行切配了,需要把这 ...
扫码加入数据分析学习群


AIU人工智能学院:数据科学、人工智能从业者的在线大学。

数据科学(Python/R/Julia)数据分析、机器学习、深度学习


作者 | CDA数据分析师

之前是把所有的菜品都洗好并放在不同的盛放的容器里。现在要进行切配了,需要把这些菜品挑选出来,比如想要做一盘凉拌黄瓜,需要先把黄瓜在他所在的容器中找出来;要做一盘可乐鸡翅,需要先从容器中把鸡翅找出来。

数据分析也是同样的道理,你要分析什么,首先要把对应的数据筛选出来。

常规的数据选择主要有列选择、行选择、行列同时选择三种方式。

一、列选择

1、选择某一列/某几列

(1)Excel实现

在Excel中选择某一列直接用鼠标选中这一列即可;如果要同时选择多列,且待选择的列不是相邻的,这个时候就可以先选中其中一列,然后按住Ctrl键不放,再选择其他列。举个例子,同时选择客户姓名和成交时间这两列,如下图所示。

https://p1.pstatp.com/large/pgc-image/5a7a02327d5d4d3aa6037c7548f3e673

(2)Python实现

在Python中我们要想获取某列只需要在表df后面的方括号中指明要选择的列名即可。如果是一列,则只需要传入一个列名;如果是同时选择多列,则传入多个列名即可,多个列名用一个list存起来。

https://p1.pstatp.com/large/pgc-image/c011040685214489b3fda12830e9be8b
https://p9.pstatp.com/large/pgc-image/5c065b827b8f4de598ef14703d9eaa63

在Python中我们把这种通过传入列名选择数据的方式称为普通索引。

除了传入具体的列名,我们还可以传入具体列的位置,即第几列,对数据进行选取,通过传入位置来获取数据时需要用到iloc方法。

https://p1.pstatp.com/large/pgc-image/03508c758eb54cdaa2258cc12a57abc8

在上面的代码中,iloc 后的方括号中逗号之前的部分表示要获取的行的位置,只输入一个冒号,不输入任何数值表示获取所有的行;逗号之后的方括号表示要获取的列的位置,列的位置同样是也是从0开始计数。

我们把这种通过传入具体位置来选择数据的方式称为位置索引。

https://p1.pstatp.com/large/pgc-image/d3193b147efb44479d3c4e7ab5f71248

2、选择连续的某几列

(1)Excel实现

在Excel中,要选择连续的几列时,直接用鼠标选中这几列即可操作。当然了,你也可以先选择一列,然后按住 Ctrl 键再去选择其他列,由于要选取的列是连续的,因此没必要这么麻烦。

(2)Python实现

在Python中可以通过前面介绍的普通索引和位置索引获取某一列或多列的数据。当你要获取的是连续的某几列,用普通索引和位置索引也是可以做到的,但是因为你要获取的列是连续的,所以只要传入这些连续列的位置区间即可,同样需要用到 iloc方法。

https://p1.pstatp.com/large/pgc-image/2df06120f65f4be9ad70a1ab5012499a

在上面的代码中,iloc 后的方括号中逗号之前的表示选择的行,当只传入一个冒号时,表示选择所有行;逗号后面表示要选择列的位置区间,0:3表示选择第1列到第4列之间的值(包含第1列但不包含第4列),我们把这种通过传入一个位置区间来获取数据的方式称为切片索引。

二、行选择

1、选择某一行/某几行

(1)Excel实现

在Excel中选择行与选择列的方式是一样的,先选择一行,按住Ctrl键再选择其他行。

(2)Python实现

在Python中,获取行的方式主要有两种,一种是普通索引,即传入具体行索引的名称,需要用到loc方法;另一种是位置索引,即传入具体的行数,需要用到iloc方法。

为了让大家看得更清楚,我们对行索引进行自定义。

https://p3.pstatp.com/large/pgc-image/82ccff459e6c4dcab067a5619d2649f2
https://p1.pstatp.com/large/pgc-image/6e69727de0164cd2b24f8de01675e8cb

2、选择连续的某几行

(1)Excel实现

在Excel中选择连续的某几行与选择连续的某几列方法一致,不再赘述。

(2)Python实现

在Python中,选择连续的某几行时,你同样可以把要选择的每一个行索引名字或者行索引的位置输进去。很显然这是没有必要的,只要把连续行的位置用一个区间表示,然后传给iloc即可。

https://p3.pstatp.com/large/pgc-image/72078a2591334fd79f7a3c9bf8edd9dd

3、选择满足条件的行

前两节获取某一列时,获取的是这一列的所有行,我们还可以只筛选出这一列中满足条件的值。

比如年龄这一列,需要把非异常值(大于200的属于异常值),即小于200岁的年龄筛选出来,该怎么实现呢?

(1)Excel实现

在Excel中我们直接使用筛选功能,将满足条件的值筛选出来,筛选方法如下图所示。

https://p3.pstatp.com/large/pgc-image/0833c408fba34679a86ca9c115338fcc

筛选年龄小于200的数据前后的对比如下图所示。

https://p3.pstatp.com/large/pgc-image/35249d25294f437aba702ada8455a024

(2)Python实现

在Python中,我们直接在表名后面指明哪列要满足什么条件,就可以把满足条件的数据筛选出来。

https://p3.pstatp.com/large/pgc-image/4d2806ada8754ff7b13138ec3880c154

我们把上面这种通过传入一个判断条件来选择数据的方式称为布尔索引。

传入的条件还可以是多个,如下为选择的年龄小于200且唯一识别码小于102的数据。

https://p1.pstatp.com/large/pgc-image/5eab2ce3d322404a8e8e4221a27a7959
https://p1.pstatp.com/large/pgc-image/a0c8fcb3e80442608c293f1fcc2513b9

三、行列同时选择

上面的数据选择都是针对单一的行或列进行选择,实际业务中我们也会用到行、列同时选择,所谓的行、列同时选择就是选择出行和列的相交部分。

例如,我们要选择第二、三行和第二、三列相交部分的数据,下图中的阴影部分就是最终的选择结果。

https://p1.pstatp.com/large/pgc-image/95b551f41f1e483bb7d1269f713f58f9

行列同时选择在Excel中主要是通过鼠标拖曳实现的,与前面的单一行/列选择方法一致,此处不再赘述,接下来主要讲讲在Python中如何实现。

1、普通索引+普通索引选择指定的行和列

普通索引+普通索引就是通过同时传入行和列的索引名称进行数据选择,需要用到loc方法。

https://p1.pstatp.com/large/pgc-image/f019996418484f6e949f680f137e10b9

loc方法中的第一对方括号表示行索引的选择,传入行索引名称;loc方法中的第二对方括号表示列索引的选择,传入列索引名称。

2、位置索引+位置索引选择指定的行和列

位置索引+位置索引是通过同时传入行、列索引的位置来获取数据,需要用到iloc方法。

https://p3.pstatp.com/large/pgc-image/54e5e2c5ff6045f2b79d7fee722aef7c

在 iloc 方法中的第一对方括号表示行索引的选择,传入要选择行索引的位置;第二对方括号表示列索引的选择,传入要选择列索引的位置。行和列索引的位置都是从0开始计数。

https://p1.pstatp.com/large/pgc-image/2503182dcfcf4635b0a7cf103d4b4b02

3、布尔索引+普通索引选择指定的行和列

布尔索引+普通索引是先对表进行布尔索引选择行,然后通过普通索引选择列。

https://p1.pstatp.com/large/pgc-image/b24c2628a4334fe9b4966dfb5fec737a

上面的代码表示选择年龄小于200的订单编号和年龄,先通过布尔索引选择出年龄小于200的所有行,然后通过普通索引选择订单编号和年龄这两列。

4、切片索引 + 切片索引选择指定的行和列

切片索引 + 切片索引是通过同时传入行、列索引的位置区间进行数据选择。

https://p1.pstatp.com/large/pgc-image/e840fffe77644a098e57d09427084f90

5、切片索引 + 普通索引选择指定的行和列


前面我们说过,如果是普通索引,就直接传入行或列名,用 loc 方法即可;如果是切片索引,也就是传入行或者列的位置区间,要用 iloc 方法。如果是切片索引+普通索引,也就是行(列)用切片索引,列(行)用普通索引,这种交叉索引要用ix方法。

关注“AIU人工智能实验室”,回复“录播”获取更多人工智能精选直播视频!


「经管之家」APP:经管人学习、答疑、交友,就上经管之家!
免流量费下载资料----在经管之家app可以下载论坛上的所有资源,并且不额外收取下载高峰期的论坛币。
涵盖所有经管领域的优秀内容----覆盖经济、管理、金融投资、计量统计、数据分析、国贸、财会等专业的学习宝库,各类资料应有尽有。
来自五湖四海的经管达人----已经有上千万的经管人来到这里,你可以找到任何学科方向、有共同话题的朋友。
经管之家(原人大经济论坛),跨越高校的围墙,带你走进经管知识的新世界。
扫描下方二维码下载并注册APP
本文关键词:

本文论坛网址:https://bbs.pinggu.org/thread-8305240-1-1.html

人气文章

1.凡人大经济论坛-经管之家转载的文章,均出自其它媒体或其他官网介绍,目的在于传递更多的信息,并不代表本站赞同其观点和其真实性负责;
2.转载的文章仅代表原创作者观点,与本站无关。其原创性以及文中陈述文字和内容未经本站证实,本站对该文以及其中全部或者部分内容、文字的真实性、完整性、及时性,不作出任何保证或承若;
3.如本站转载稿涉及版权等问题,请作者及时联系本站,我们会及时处理。
联系客服
值班时间:工作日(9:00--18:00)