详谈Pandas中iloc和loc以及ix的区别
程序员文章站
2023-11-09 10:18:10
pandas库中有iloc和loc以及ix可以用来索引数据,抽取数据。但是方法一多也容易造成混淆。下面将一一来结合代码说清其中的区别。
1. iloc和loc的区别:...
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
以上这篇详谈pandas中iloc和loc以及ix的区别就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
推荐阅读
-
详谈Pandas中iloc和loc以及ix的区别
-
pandas ix &iloc &loc的区别
-
Pandas中关于数据索引iloc()和loc()的用法和区别
-
聊聊Python pandas 中loc函数的使用,及跟iloc的区别说明
-
浅谈pandas中Dataframe的查询方法([], loc, iloc, at, iat, ix)
-
详谈pandas中agg函数和apply函数的区别
-
Pandas中loc,iloc与直接切片的区别
-
详谈Pandas中iloc和loc以及ix的区别
-
Python Pandas DataFrame:查询数据or选择数据(selection)之loc,iloc,at,iat,ix的用法和区别
-
Pandas中关于数据索引iloc()和loc()的用法和区别