国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

在pandas多重索引multiIndex中選定指定索引的行方法

2020-01-04 14:03:17
字體:
供稿:網(wǎng)友

multiIndex中選定指定索引的行

我們在用pandas類似groupby來使用多重index時(shí),有時(shí)想要對多個(gè)level中的某個(gè)index對應(yīng)的行進(jìn)行操作,就需要在dataframe中找到該index對應(yīng)的行,在單層index中我們可以方便的使用df.loc[index]來選擇,在多重Index中我們可以利用的類似的思路,然而其中也有一些小坑,記錄如下。

1 index為有序的

1.1 創(chuàng)建測試數(shù)據(jù)

首先創(chuàng)建一個(gè)dataframe數(shù)據(jù)

df = pd.DataFrame({'class':['A','A','A','B','B','B','C','C'],   'id':['a','b','c','a','b','c','a','b'],   'value':[1,2,3,4,5,6,7,8]})

df中內(nèi)容如下圖:

pandas,多重索引,multiIndex

1.2 設(shè)置multiIndex

通過set_index設(shè)為多重索引

df = df.set_index(['class','id'])

設(shè)置索引后效果:

pandas,多重索引,multiIndex

1.3 切片篩選index

這里同樣使用loc定位

df.loc[('A',slice(None)),:]

各參數(shù)的解釋如下:

loc[(a,b),c]中第一個(gè)參數(shù)元組為索引內(nèi)容,a為level0索引對應(yīng)的內(nèi)容,b為level1索引對應(yīng)的內(nèi)容

因?yàn)閐f是一個(gè)dataframe,所以要用c來指定列

這里‘A',指選擇class中的A類

slice(None), 是Python中的切片操作,這里用來選擇任意的id,要注意!不能使用‘:'來指定任意index

‘:',用來指定dataframe任意的列

執(zhí)行后的結(jié)果如下:

pandas,多重索引,multiIndex

同樣,如果想只保留id中的'a',則可以使用:

df.loc[(slice(None),'a'),:]

2 index無序

前面的例子對應(yīng)的index列為數(shù)字或字母,是有序的,接下來我們看看index列為中文的情況。

2.1 創(chuàng)建無序測試數(shù)據(jù)

df2 = pd.DataFrame({'課程':['語文','語文','數(shù)學(xué)','數(shù)學(xué)'],'得分':['最高','最低','最高','最低'],'分值':[90,50,100,60]})df2 = df2.set_index(['課程','得分'])

pandas,多重索引,multiIndex

2.2 嘗試切片選擇index

df2.loc[('語文',slice(None)),:]

我們進(jìn)行同樣的操作,這時(shí)會(huì)發(fā)現(xiàn)提示出錯(cuò):

UnsortedIndexError: 'MultiIndex Slicing requires the index to be fully lexsorted tuple len (2), lexsort depth (0)'

這是因?yàn)榇藭r(shí)的index無法進(jìn)行排序,在pandas文檔中提到:Furthermore if you try to index something that is not fully lexsorted, this can raise:

我們可以通過 df2.index.is_lexsorted()來檢查index是否有序,

In[1]: df2.index.is_lexsorted()out[1]: False

接下來,我們嘗試對Index進(jìn)行排序。(排序時(shí)要在level里指定index名)

2.3 對index排序后切片選擇index

df2 = df2.sort_index(level='課程')
df2.loc[('語文',slice(None)),:]

pandas,多重索引,multiIndex

得到了我們想要的結(jié)果。

參考文獻(xiàn):pandas-docs-MultiIndex / Advanced Indexing

以上這篇在pandas多重索引multiIndex中選定指定索引的行方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持VEVB武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請移步到python教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 西峡县| 玉田县| 赣榆县| 峨眉山市| 香港| 西青区| 丹凤县| 天祝| 沂南县| 乌鲁木齐县| 双流县| 山东省| 鹿邑县| 孟村| 宿迁市| 图木舒克市| 湖北省| 平原县| 兰溪市| 峨山| 宁河县| 当阳市| 南充市| 田林县| 柘城县| 苗栗县| 莫力| 沈丘县| 云南省| 肇庆市| 吴川市| 都匀市| 冷水江市| 南漳县| 黑龙江省| 永仁县| 白城市| 河池市| 四子王旗| 阿克陶县| 荆门市|