欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

pandas 實現(xiàn)分組后取第N行

 更新時間:2021年03月26日 10:55:10   作者:NoOne-csdn  
這篇文章主要介紹了pandas 實現(xiàn)分組后取第N行的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

目的:

把question_id 對應(yīng)的user_answer轉(zhuǎn)成ABCD

solution

dfa=df.groupby('question_id').nth(0).reset_index()
dfa['flag']='A'
dfb=df.groupby('question_id').nth(1).reset_index()
dfb['flag']='B'
dfc=df.groupby('question_id').nth(2).reset_index()
dfc['flag']='C'
dfd=df.groupby('question_id').nth(3).reset_index()
dfd['flag']='D'

resdf=dfa.append([dfb,dfc,dfd])
resdf.sort_values(by='question_id')

result

focus

g.nth(0) 
#同 
g.first()
g.head(1)
g.last()

g.nth(2)
g.nth(-1)

g.nth(0,dropna='any')
g.B.nth(0,dropna='all')
g.groups
g.get_group(134429)
g.discribe()
g.agg([np.mean,np.sum.np,std])

補(bǔ)充:pandas的分組取最大多行并求和函數(shù)nlargest()

在pandas庫里面,我們常常關(guān)心的是最大的前幾個,比如銷售最好的幾個產(chǎn)品,幾個店,等。之前講到的head(), 能夠看到看到DF里面的前幾行,如果需要看到最大或者最小的幾行就需要先進(jìn)行排序。max()和min()可以看到最大或者最小值,但是只能看到一個值。

所以我們可以使用nlargest()函數(shù),nlargest()的優(yōu)點就是能一次看到最大的幾行,而且不需要排序。缺點就是只能看到最大的,看不到最小的。

我們來看看單價排在前十的數(shù)據(jù):

單價排在前十的數(shù)據(jù)

nlargest()的第一個參數(shù)就是截取的行數(shù)。第二個參數(shù)就是依據(jù)的列名。

這樣就可以篩選出單價最高的前十行,而且是按照單價從最高到最低進(jìn)行排列的,所以還是按照之前的索引。

還可以按照total_price來進(jìn)行排名:

按照total_price排名

nlargest還有一個參數(shù),keep='first'或者'last'。當(dāng)出現(xiàn)重復(fù)值的時候,keep='first',會選取在原始DataFrame里排在前面的,keep='last'則去排后面的。

由于nlagerst()不能去最小的多個值,如果我們一定要使用這個函數(shù)進(jìn)行選取也是可以的.

先設(shè)置一個輔助列:

先設(shè)置一個輔助列

然后在進(jìn)行選?。?/p>

以輔助列進(jìn)行選取

當(dāng)然了,也可以通過head()加上排序進(jìn)行選取的。

那以前這些操作都可以通過其它函數(shù)來進(jìn)行替代的話,nlargest()有什么必要介紹嗎?或者說學(xué)不學(xué)這個函數(shù)有什么關(guān)系嗎?

這就是我們今天要重點介紹的,如果說要選擇不同location_road下的前五名要怎么操作呢?

很多人可能第一反應(yīng)會想到先分組然后進(jìn)行max()操作,但是這樣的操作只能選擇最大的一列:

使用max()

但是使用max有一個問題,就是選取的是每一列的最大值,而不是選取最大值的那一行,也就是說只能在選取單列的最大值的時候才是準(zhǔn)確的。

這個時候我們就要想到apply和lambda的自定義函數(shù)了:

選取多個指標(biāo)的TOP(N)

這樣就選出了不同loaction_road的price排在前五的行了。

nlargest()函數(shù)在這種場景下使用是非常方便的,而且結(jié)果也已經(jīng)默認(rèn)排好順序了。

還有一些場景下需要計算分組的前幾名,然后在進(jìn)行求和的,這個我們也可以使用nlargest進(jìn)行操作:

分組之后進(jìn)行求和

使用這種方法會出現(xiàn)報錯提示,這個因為在列和索引都存在loaction_road,有重復(fù),系統(tǒng)有警告,在實際使用時可以先改列名再操作。我們也可以換一種方式直接按照索引進(jìn)行求和,這樣就沒有警告了:

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • Python pass語句作用和Python assert斷言函數(shù)的用法

    Python pass語句作用和Python assert斷言函數(shù)的用法

    這篇文章主要介紹了Python pass語句作用和Python assert斷言函數(shù)的用法,文章內(nèi)容介紹詳細(xì)具有一定的參考價值,需要的小伙伴可以參考一下,希望對你有所幫助
    2022-03-03
  • python對視頻畫框標(biāo)記后保存的方法

    python對視頻畫框標(biāo)記后保存的方法

    今天小編就為大家分享一篇python對視頻畫框標(biāo)記后保存的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • python使用PythonMagick將jpg圖片轉(zhuǎn)換成ico圖片的方法

    python使用PythonMagick將jpg圖片轉(zhuǎn)換成ico圖片的方法

    這篇文章主要介紹了python使用PythonMagick將jpg圖片轉(zhuǎn)換成ico圖片的方法,涉及PythonMagick模塊操作圖片的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • 如何利用Fabric自動化你的任務(wù)

    如何利用Fabric自動化你的任務(wù)

    大家都知道Fabric是一個Python庫,可以通過SSH在多個host上批量執(zhí)行任務(wù)。你可以編寫任務(wù)腳本,然后通過Fabric在本地就可以使用SSH在大量遠(yuǎn)程服務(wù)器上自動運行。這些功能非常適合應(yīng)用的自動化部署,或者執(zhí)行系統(tǒng)管理任務(wù)。本文將介紹如何利用Fabric自動化你的任務(wù)。
    2016-10-10
  • Python 中的lambda函數(shù)介紹

    Python 中的lambda函數(shù)介紹

    Lambda函數(shù),即Lambda 表達(dá)式(lambda expression),是一個匿名函數(shù)(不存在函數(shù)名的函數(shù)),這篇文章主要介紹了Python lambda函數(shù)的基礎(chǔ)知識,需要的朋友可以參考下
    2018-10-10
  • PyMongo安裝使用筆記

    PyMongo安裝使用筆記

    這篇文章主要介紹了PyMongo安裝使用筆記,本文講解使用pip方式安裝PyMongo,并給出一個pymongo的簡單使用代碼實例,需要的朋友可以參考下
    2015-04-04
  • Python實現(xiàn)基于socket的udp傳輸與接收功能詳解

    Python實現(xiàn)基于socket的udp傳輸與接收功能詳解

    這篇文章主要介紹了Python實現(xiàn)基于socket的udp傳輸與接收功能,結(jié)合實例形式詳細(xì)分析了Python使用socket進(jìn)行udp文件傳輸與接收相關(guān)操作技巧及注意事項,需要的朋友可以參考下
    2019-11-11
  • TensorFlow的環(huán)境配置與安裝方法

    TensorFlow的環(huán)境配置與安裝方法

    這篇文章主要介紹了TensorFlow的環(huán)境配置與安裝方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • 使用python檢測網(wǎng)頁文本內(nèi)容屏幕上的坐標(biāo)

    使用python檢測網(wǎng)頁文本內(nèi)容屏幕上的坐標(biāo)

    在 Web 開發(fā)中,經(jīng)常需要對網(wǎng)頁上的文本內(nèi)容進(jìn)行處理和操作,有時候,我們可能需要知道某個特定文本在屏幕上的位置,以便進(jìn)行后續(xù)的操作,所以本文將介紹如何使用 Python 中的 Selenium 和 BeautifulSoup 庫來檢測網(wǎng)頁文本內(nèi)容在屏幕上的坐標(biāo),需要的朋友可以參考下
    2024-04-04
  • PyTorch中torch.nn.Linear實例詳解

    PyTorch中torch.nn.Linear實例詳解

    torch.nn是包含了構(gòu)筑神經(jīng)網(wǎng)絡(luò)結(jié)構(gòu)基本元素的包,在這個包中可以找到任意的神經(jīng)網(wǎng)絡(luò)層,下面這篇文章主要給大家介紹了關(guān)于PyTorch中torch.nn.Linear的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-06-06

最新評論