Pandas库中有iloc和loc以及ix可以用来索引数据,抽取数据。但是方法一多也容易造成混淆。下面将一一来结合代码说清其中的区别。

1. iloc和loc的区别:

iloc主要使用数字来索引数据,而不能使用字符型的标签来索引数据。而loc则刚好相反,只能使用字符型标签来索引数据,不能使用数字来索引数据,不过有特殊情况,当数据框dataframe的行标签或者列标签为数字,loc就可以来其来索引。

好,先上代码,先上行标签和列标签都为数字的情况。

import pandas as pd

import numpy as np

a = np.arange(12).reshape(3,4)

print a

>>>

[[ 0 1 2 3]

[ 4 5 6 7]

[ 8 9 10 11]]

df = pd.DataFrame(a)

print df

>>>

0 1 2 3

0 0 1 2 3

1 4 5 6 7

2 8 9 10 11

print df.loc[0]

>>>

0 0

1 1

2 2

3 3

Name: 0, dtype: int32

print df.iloc[0]

0 0

1 1

2 2

3 3

Name: 0, dtype: int32

print df.loc[:,[0,3]]

0 3

0 0 3

1 4 7

2 8 11

print df.iloc[:,[0,3]]

0 3

0 0 3

1 4 7

2 8 11

接下来是把行标签[0, 1, 2]改成['a', 'b', 'c'],则成这样了。

df.index = ['a','b','c']

print df

>>>

0 1 2 3

a 0 1 2 3

b 4 5 6 7

c 8 9 10 11

print df.loc[0]

# TypeError: cannot do label indexing on with these indexers [0] of

print df.iloc[0]

>>>

0 0

1 1

2 2

3 3

Name: a, dtype: int32

print df.iloc['a'] # TypeError: cannot do positional indexing on with these indexers [a] of

print df.loc['a'] # 正确

>>>

0 0

1 1

2 2

3 3

Name: a, dtype: int32

同样地,把列标签[0, 1, 2, 3]改成['A', 'B, 'C', 'D'],则成这样了。

df.columns = ['A','B','C','D']

print df

>>>

A B C D

a 0 1 2 3

b 4 5 6 7

c 8 9 10 11

print df.loc[:,'A']

>>>

a 0

b 4

c 8

Name: A, dtype: int32

print df.iloc[:,'A'] # ValueError: Location based indexing can only have [integer, integer slice (START point is INCLUDED, END point is EXCLUDED), listlike of integers, boolean array] types

2.ix是一种混合索引,字符型标签和整型数据索引都可以。

print df.ix[0]

>>>

A 0

B 1

C 2

D 3

Name: a, dtype: int32

print df.ix['a']

>>>

A 0

B 1

C 2

D 3

Name: a, dtype: int32

print df.ix[:,0]

>>>

a 0

b 4

c 8

Name: A, dtype: int32

print df.ix[:,'A']

>>>

a 0

b 4

c 8

Name: A, dtype: int32

以上这篇详谈Pandas中iloc和loc以及ix的区别就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

python中的ix是啥_详谈Pandas中iloc和loc以及ix的区别相关推荐

  1. python怎么选取不连续的列_用pandas中的DataFrame时选取行或列的方法

    如下所示: import numpy as np import pandas as pd from pandas import Sereis, DataFrame ser = Series(np.ar ...

  2. Pandas的iloc、loc、ix的区别

    (作者:陈玓玏) 1.例子 取DataFrame的部分数据,或者修改部分数据是非常非常常见的操作,但是实际应用中,到底使用ix方法,还是iloc方法,还是loc方法,还需要讨论.请看下面的实验: im ...

  3. pandas的iloc、loc、ix的使用(列切片及行切片)

    loc:通过选取行(列)标签索引数据 iloc:通过选取行(列)位置编号索引数据 ix:既可以通过行(列)标签索引数据,也可以通过行(列)位置编号索引数据df是一个dataframe,列名为A B C ...

  4. python ix loc iloc_pandas中的iloc、loc、ix有什么区别?

    pandas的初学者都会有一个疑惑,经常看别人的代码有iloc.loc.ix,这三个函数到底有什么区别呢? 首先,这三个都可以用来筛选行列,即filter特定的行.列或者同时选取行列,那么他们三个有什 ...

  5. python时间函数报错_python3中datetime库,time库以及pandas中的时间函数区别与详解...

    1介绍datetime库之前 我们先比较下time库和datetime库的区别 先说下time 在 Python 文档里,time是归类在Generic Operating System Servic ...

  6. python获取系统时间函数_python3中datetime库,time库以及pandas中的时间函数区别与详解...

    1介绍datetime库之前 我们先比较下time库和datetime库的区别 先说下time 在 Python 文档里,time是归类在Generic Operating System Servic ...

  7. Python语言编程学习:numpy中的array格式数据切片与pandas中的dataframe格式数据切片、相互转换

    Python语言编程学习:numpy中的array格式数据切片与pandas中的dataframe格式数据切片.相互转换 目录 numpy中的array格式数据切片与pandas中的dataframe ...

  8. pandas中的切片函数: .iloc()、.loc()、.ix() 的区别

    文章目录 pandas中的切片函数:`.iloc()`.`.loc()`.`.ix()` 1.首先创建一个DataFrame iloc:通过行/列号选取数据 1. .iloc就是通过行/列号来选取数据 ...

  9. Pandas中iloc、loc、ix三者的区别

    一.综述:iloc.loc.ix可以用来索引数据.抽取数据 二.iloc.loc.ix三者对比 iloc和loc的区别 iloc主要使用数字来索引数据,不能使用字符型的标签来索引数据. loc只能使用 ...

最新文章

  1. 【好程序员笔记分享】——下拉刷新和上拉加载更多
  2. 屏蔽wget下载网站内容
  3. Cocos2d Box2D之简介
  4. Linux学习笔记五:arm-2009q3交叉编译环境安装、U盘拷贝文件到开发板
  5. seay代码审计工具_代码审计入门实战
  6. 高效程序员的45个习惯
  7. 一图掌握ICT项目管理流程图【实例】
  8. android加速度传感器 源码,Android项目源码利用加速度传感器实现计步
  9. 一个三流学校程序员的奋斗!(转)
  10. WINVER 和 _WIN32_WINNT
  11. kinect for Unity开发
  12. jquery禁用右键、文本选择功能、复制的代码
  13. python单一数字取对数与数列取对数
  14. 【C语言习题】两素数之差为2,则称该两素数为双胞胎数。求出[2,300]内双胞胎数。
  15. HTML表格(二)---成绩单
  16. 小米6鲁大师html5评测,小米6跑分超110万?鲁大师官方:网友PS的图片
  17. 函数 函数的基本使用 函数的四种基本形式 可选参数 函数默认参数 函数的剩余参数 构造函数() 函数重(chong)载
  18. WCS仓库(分拣)控制系统 案例介绍
  19. 事件营销有哪些策略?
  20. Lyapunov函数对微分方程稳定性的判别

热门文章

  1. mysql的中文乱码url,MySQL 中文显示乱码
  2. 第12章 存储器的保护
  3. R语言安装;Rstudio安装
  4. 目标检测近5年发展历程概述(转)
  5. centos6.8 安装软件
  6. FFmpeg开发实战(三):FFmpeg 打印音视频Meta信息
  7. PHP函数之HTMLSPECIALCHARS_DECODE
  8. Docker的学习笔记(开发的技术分享转发)
  9. 【大数据】Hadoop入门预告版
  10. JQuery学习记录——DOM的加载