詳談Pandas中iloc和loc以及ix的區(qū)別
Pandas庫(kù)中有iloc和loc以及ix可以用來(lái)索引數(shù)據(jù),抽取數(shù)據(jù)。但是方法一多也容易造成混淆。下面將一一來(lái)結(jié)合代碼說(shuō)清其中的區(qū)別。
1. iloc和loc的區(qū)別:
iloc主要使用數(shù)字來(lái)索引數(shù)據(jù),而不能使用字符型的標(biāo)簽來(lái)索引數(shù)據(jù)。而loc則剛好相反,只能使用字符型標(biāo)簽來(lái)索引數(shù)據(jù),不能使用數(shù)字來(lái)索引數(shù)據(jù),不過(guò)有特殊情況,當(dāng)數(shù)據(jù)框dataframe的行標(biāo)簽或者列標(biāo)簽為數(shù)字,loc就可以來(lái)其來(lái)索引。
好,先上代碼,先上行標(biāo)簽和列標(biāo)簽都為數(shù)字的情況。
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
接下來(lái)是把行標(biāo)簽[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
同樣地,把列標(biāo)簽[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是一種混合索引,字符型標(biāo)簽和整型數(shù)據(jù)索引都可以。
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的區(qū)別就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- Python Pandas數(shù)據(jù)分析之iloc和loc的用法詳解
- 聊聊Python pandas 中l(wèi)oc函數(shù)的使用,及跟iloc的區(qū)別說(shuō)明
- python選取特定列 pandas iloc,loc,icol的使用詳解(列切片及行切片)
- 一文秒懂pandas中iloc()函數(shù)
- 利用Pandas讀取某列某行數(shù)據(jù)之loc和iloc用法總結(jié)
- Pandas中的loc與iloc區(qū)別與用法小結(jié)
- 對(duì)pandas中iloc,loc取數(shù)據(jù)差別及按條件取值的方法詳解
- Python?Pandas中l(wèi)oc和iloc函數(shù)的基本用法示例
- python中pandas庫(kù)的iloc函數(shù)用法解析
- Pandas索引器 loc 和 iloc 比較及代碼示例
相關(guān)文章
Python中使用多進(jìn)程來(lái)實(shí)現(xiàn)并行處理的方法小結(jié)
本篇文章主要介紹了Python中使用多進(jìn)程來(lái)實(shí)現(xiàn)并行處理的方法小結(jié),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08
python實(shí)現(xiàn)一個(gè)通用的插件類
插件管理器用于注冊(cè)、銷毀、執(zhí)行插件,本文主要介紹了python實(shí)現(xiàn)一個(gè)通用的插件類,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-04-04
將tensorflow的ckpt模型存儲(chǔ)為npy的實(shí)例
今天小編就為大家分享一篇將tensorflow的ckpt模型存儲(chǔ)為npy的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-07-07
Python?Playwright庫(kù)從入門到實(shí)戰(zhàn)教程
Playwright是一個(gè)用于自動(dòng)化Web瀏覽器測(cè)試的庫(kù),它提供了一種高級(jí)的API來(lái)模擬用戶行為,無(wú)論是在自動(dòng)化測(cè)試、爬蟲還是生成復(fù)雜的用戶交互場(chǎng)景中都非常有用,這篇文章主要介紹了Python?Playwright庫(kù)從入門到實(shí)戰(zhàn)的相關(guān)資料,需要的朋友可以參考下2025-12-12
Python多進(jìn)程并發(fā)與同步機(jī)制超詳細(xì)講解
進(jìn)程(Process),顧名思義,就是進(jìn)行中的程序。有一句話說(shuō)得好:程序是一個(gè)沒(méi)有生命的實(shí)體,只有處理器賦予程序生命時(shí),它才能成為一個(gè)活動(dòng)的實(shí)體。進(jìn)程是資源分配的最小單元,也就是說(shuō)每個(gè)進(jìn)程都有其單獨(dú)的內(nèi)存空間2022-12-12

