Python pandas之多級索引取值詳解
最近發(fā)現(xiàn)周圍的很多小伙伴們都不太樂意使用pandas,轉(zhuǎn)而投向其他的數(shù)據(jù)操作庫,身為一個數(shù)據(jù)工作者,基本上是張口pandas,閉口pandas了,故而寫下此系列以讓更多的小伙伴們愛上pandas。
平臺:
windows 10
python 3.8
pandas 1.2.4
數(shù)據(jù)需求
給定一份多級索引數(shù)據(jù),查找指定值。
需求拆解
數(shù)據(jù)提取在pandas中,或者說在python中就是索引式提取,在單層索引中采用.loc
或.iloc
方法已經(jīng)非常常見了,然而在索引層次多了之后卻有點不知所措,也只需要將各個索引看成整體進行提取就行。
需求處理
方法一
這里先給出一個比較笨拙的方法,先將索引進行重置為列數(shù)據(jù),通過列取得bool條件再進行提取
datac.reset_index(inplace=True) datac[(datac['School'] == 'S_2') & (datac['Class'] == 'C_3')]
可以看到通過該類方法可以成功取到對應(yīng)值
當然也可以采用.query
方法進行條件篩選
datac.reset_index(inplace=True) datac.query("School == 'S_1' and Class == 'C_3'")
方法二
既然為多級索引,pandas也會有對應(yīng)的取值方式,既可以用鏈式調(diào)用的方式,也可以通過元組進行提取,首先看看多級索引的輸出值:
是一個MultiIndex類型數(shù)據(jù),其元素都是元組,即也能通過元組的方式進行索引調(diào)取
這兩種都一個共同的特點,從左到右,要先外層再內(nèi)層,否則會報KeyError
錯誤
# 鏈式調(diào)用 datac.loc['S_1'].loc['C_1']
# 元組作為索引調(diào)用 datac.loc[('S_3', 'C_1'), :]
tips:
1.多層索引,即列名上方有層次結(jié)構(gòu)也可以按這種方式進行提取。
2.想越過外層索引提取內(nèi)層索引需要交換索引順序才能順利提取。
# swaplevel 交換索引層級 datac.swaplevel(axis=0).loc[('C_1')] # axis=0: index
總結(jié)
功夫再高,也怕菜刀。本例使用方法比較常規(guī),旨在鞏固基礎(chǔ)知識,當下次遇到能夠想起可以直接索引取值而不用將索引重置為列值,以高效完成數(shù)據(jù)提取任務(wù)。
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Django實現(xiàn)whoosh搜索引擎使用jieba分詞
這篇文章主要介紹了Django實現(xiàn)whoosh搜索引擎使用jieba分詞,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04Django的HttpRequest和HttpResponse對象詳解
這篇文章主要介紹了Django的HttpRequest和HttpResponse對象,分享了相關(guān)代碼示例,小編覺得還是挺不錯的,具有一定借鑒價值,需要的朋友可以參考下2018-01-01Pygame游戲開發(fā)之太空射擊實戰(zhàn)盾牌篇
相信大多數(shù)8090后都玩過太空射擊游戲,在過去游戲不多的年代太空射擊自然屬于經(jīng)典好玩的一款了,今天我們來自己動手實現(xiàn)它,在編寫學習中回顧過往展望未來,在本課中,我們將為玩家添加一個盾牌以及一個用于顯示盾牌等級的欄2022-08-08python 把數(shù)據(jù) json格式輸出的實例代碼
下面小編就為大家?guī)硪黄猵ython 把數(shù)據(jù) json格式輸出的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10Python函數(shù)sort()與sorted()的區(qū)別及key=lambda?x:x[]的理解
這篇文章主要介紹了Python函數(shù)sort()與sorted()的區(qū)別及key=lambda?x:x[]的理解方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08