国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > 詳解DataFrame.loc

詳解DataFrame.loc

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-11-23 19:40:28 1700739628

一、用途與特點

DataFrame是Pandas中最重要的數(shù)據(jù)結(jié)構(gòu)之一,而DataFrame.loc則是對于DataFrame進(jìn)行行列選取的一種方法。它通過行標(biāo)簽名和列標(biāo)簽名進(jìn)行數(shù)據(jù)選取。

相對于其他方法,DataFrame.loc具有更高的靈活性和準(zhǔn)確性。與iloc根據(jù)行列的位置來進(jìn)行選取不同,使用loc可以根據(jù)行列的標(biāo)簽名稱來進(jìn)行選取。并且在同時進(jìn)行行列選取時,使用loc的效率更高。


    # 用于基于標(biāo)簽的索引(即行列標(biāo)簽)進(jìn)行選擇
    # df.loc[row, column]
    # row可以是行標(biāo)簽也可以是布爾數(shù)組,column可以是列標(biāo)簽也可以是布爾數(shù)組

二、基本用法

選擇某些列:


    import pandas as pd
    import numpy as np

    df = pd.DataFrame(np.random.randn(6,4), columns=list('ABCD'), index=list('abcdef'))

    # 根據(jù)標(biāo)簽獲取列數(shù)據(jù)
    print(df.loc[:, ['A', 'B']])

選擇某些行:


    # 根據(jù)標(biāo)簽獲取行數(shù)據(jù)
    print(df.loc[['a', 'b', 'f'], :])

選擇某個區(qū)域的數(shù)據(jù):


    # 根據(jù)標(biāo)簽獲取行和列的區(qū)域數(shù)據(jù)
    print(df.loc['d':'f', 'A':'C'])

三、高級用法

布爾索引

在DataFrame.loc中使用布爾值可以進(jìn)行高級篩選。


    # 布爾索引
    df.loc[df['A'] > 0, ['A','B']]

使用函數(shù)進(jìn)行映射

在DataFrame中使用applymap或apply方法可以對數(shù)據(jù)進(jìn)行轉(zhuǎn)換。在.loc后使用,我們可以完成數(shù)據(jù)篩選和轉(zhuǎn)換的一步操作。


    # 對篩選出來的數(shù)據(jù)進(jìn)行applymap的map函數(shù)映射操作
    df.loc[df['A'] > 0, ['A','B']].applymap(lambda x: x*2)

使用where方法

使用where方法進(jìn)行條件篩選。對于篩選為False的數(shù)據(jù),其對應(yīng)位置上的數(shù)據(jù)會被填充為NaN。


    # 對q值保留填充,而對于其他的行列標(biāo)簽均標(biāo)記為NaN
    df.loc[df['A'] > 0, 'B'] = np.nan
    df.where(pd.notna(df), df.mean(), axis='columns')

四、總結(jié)

本文基于DataFrame的高級索引方法DataFrame.loc進(jìn)行了詳細(xì)講解,介紹了其基本使用方法和高級應(yīng)用方法。

對于Pandas用戶而言,熟悉DataFrame.loc的使用方法可以幫助我們更加靈活地對數(shù)據(jù)進(jìn)行篩選和轉(zhuǎn)換。它是我們使用Pandas解決數(shù)據(jù)分析和處理問題的重要方法。

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT