详谈Pandas中iloc和loc以及ix的区别

作者:Modozil 时间:2022-01-30 00:52:49 

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 <class 'pandas.core.indexes.base.Index'> with these indexers [0] of <type 'int'>
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 <class 'pandas.core.indexes.base.Index'> with these indexers [a] of <type 'str'>
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

来源:https://blog.csdn.net/niuniuyuh/article/details/76650904

标签:Pandas,iloc,loc,ix
0
投稿

猜你喜欢

  • 存贮查询与运行时查询孰优孰劣?

    2009-11-01 15:13:00
  • Python的Web框架Django介绍与安装方法

    2021-03-06 05:46:12
  • 20分钟成功编写bootstrap响应式页面 就这么简单

    2023-08-12 06:12:13
  • asp vbcrlf是什么意思

    2011-03-30 11:03:00
  • Django如何实现网站注册用户邮箱验证功能

    2023-05-14 08:03:08
  • 《写给大家看的设计书》阅读笔记之重复原则

    2009-07-12 15:36:00
  • springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项

    2023-09-04 09:17:26
  • 使用Python抓取模板之家的CSS模板

    2022-04-09 18:35:52
  • 说说页面中header的XHTML结构选择

    2008-06-09 12:49:00
  • 虾米网今年三月所用加密解密函数

    2010-08-09 12:54:00
  • 基python实现多线程网页爬虫

    2023-10-30 00:58:48
  • Uchome1.2 1.5 代码学习 common.php

    2023-11-15 02:56:10
  • Microsoft SQL Server数据库SA权限总结

    2009-01-06 11:32:00
  • Javascript fso操作文件

    2008-07-30 12:51:00
  • Pytorch实现将label变成one hot编码的两种方式

    2021-08-26 08:45:00
  • PHP chr()函数讲解

    2023-06-05 04:03:58
  • Python实现基于权重的随机数2种方法

    2022-10-13 03:25:40
  • 利用Python实现学生信息管理系统的完整实例

    2022-03-12 10:35:03
  • CSS网页布局扩展小技巧

    2010-06-03 12:13:00
  • 教你如何使用php session

    2023-11-15 06:28:01
  • asp之家 网络编程 m.aspxhome.com