python--pandas分組聚合

分組聚合是數(shù)據(jù)處理中常見的場景,在pandas中用groupby方法實現(xiàn)分組操作,用agg方法實現(xiàn)聚合操作。

環(huán)境

  • python3.9
  • win10 64bit
  • pandas==1.2.1

groupby方法是pandas中的分組方法,對數(shù)據(jù)框采用groupby方法后,返回的是DataFrameGroupBy對象,一般分組操作后會進行聚合操作。

分組

import pandas as pd
import numpy as np
pd.set_option('display.notebook_repr_html',False)
# 數(shù)據(jù)準備
df = pd.DataFrame({'A': [1, 1, 2, 2],'B': [1, 2, 3, 4],'C':[6,8,1,9]})
df
   A  B  C
0  1  1  6
1  1  2  8
2  2  3  1
3  2  4  9

對數(shù)據(jù)框按A列進行分組,產(chǎn)生分組數(shù)據(jù)框。分組數(shù)據(jù)框是可迭代對象,可以進行循環(huán)遍歷,可以看出在循環(huán)中,每個元素的類型是元組,
元組的第一個元素是分組值,第二個元素是對應的分組數(shù)據(jù)框。

# 分組
g_df=df.groupby('A')
# 分組數(shù)據(jù)框類
type(g_df)
pandas.core.groupby.generic.DataFrameGroupBy
# 循環(huán)分組數(shù)據(jù)
for i in g_df:
    print(i,type(i),end='\n\n')
(1,    A  B  C
0  1  1  6
1  1  2  8) <class 'tuple'>

(2,    A  B  C
2  2  3  1
3  2  4  9) <class 'tuple'>

可以對分組后的數(shù)據(jù)框直接使用聚合方法agg,對分組數(shù)據(jù)框的每一列計算統(tǒng)計函數(shù)值。

# 分組求和
df.groupby('A').agg('sum')
   B   C
A       
1  3  14
2  7  10

序列分組

可以根據(jù)數(shù)據(jù)框外的序列數(shù)據(jù)對數(shù)據(jù)框進行分組,需要注意序列長度需要與數(shù)據(jù)框行數(shù)相同

# 定義分組列表
label=['a','a','b','b']
# 分組求和
df.groupby(label).agg('sum')
   A  B   C
a  2  3  14
b  4  7  10

多列分組

可以根據(jù)數(shù)據(jù)框的多列對數(shù)據(jù)框進行分組。

# 數(shù)據(jù)準備
df = pd.DataFrame({'A': [1, 1, 2, 2],'B': [3, 4, 3, 3],'C':[6,8,1,9]})
df
   A  B  C
0  1  3  6
1  1  4  8
2  2  3  1
3  2  3  9

根據(jù)A,B列進行分組,然后求和。

# 根據(jù)多列分組求和
df.groupby(['A','B']).agg('sum')
      C
A B    
1 3   6
  4   8
2 3  10

索引分組

可以根據(jù)索引對數(shù)據(jù)框進行分組,需要設置level參數(shù)。

# 數(shù)據(jù)準備
df = pd.DataFrame({'A': [1, 1, 2, 2],'B': [3, 4, 3, 3],'C':[6,8,1,9]},index=['a','a','b','b'])
df
   A  B  C
a  1  3  6
a  1  4  8
b  2  3  1
b  2  3  9

數(shù)據(jù)框只有一層索引,設置參數(shù)level=0。

# 根據(jù)索引分組求和
df.groupby(level=0).agg('sum')
   A  B   C
a  2  7  14
b  4  6  10

當數(shù)據(jù)框索引有多層時,也可以根據(jù)需求設置level參數(shù),完成分組聚合。

# 數(shù)據(jù)準備
mi=pd.MultiIndex.from_arrays([[1,1,2,2],[3,4,3,3]],names=['id1','id2'])
df=pd.DataFrame(dict(value=[4,7,2,9]),index=mi)
df
         value
id1 id2       
1   3        4
    4        7
2   3        2
    3        9

設置level參數(shù),如需要根據(jù)第一層索引,即id1進行分組,可以設置level=0level='id1'完成分組聚合。

# 根據(jù)第一層索引分組求和
df.groupby(level=0).agg('sum')
     value
id1       
1       11
2       11
# 根據(jù)第一層索引分組求和
df.groupby(level='id1').agg('sum')
     value
id1       
1       11
2       11

聚合

分組后一般會進行聚合操作,用agg方法進行聚合。

# 數(shù)據(jù)準備
df = pd.DataFrame({'A': [1, 1, 2, 2],'B': [3, 4, 3, 3],'C':[6,8,1,9],'D':[2,5,4,8]})
df
   A  B  C  D
0  1  3  6  2
1  1  4  8  5
2  2  3  1  4
3  2  3  9  8

單函數(shù)對多列

對分組后數(shù)據(jù)框使用單個函數(shù)進行聚合,單個聚合函數(shù)會對每列進行計算,然后合并返回。聚合函數(shù)以字符串的形式傳入。

# 對所有列分組求和
df.groupby('A').agg('sum')
   B   C   D
A           
1  7  14   7
2  6  10  12

可以對分組后的數(shù)據(jù)指定列進行分組聚合。需要注意子列需要用[]包裹。

# 對指定列分組求和
df.groupby('A')[['B','C']].agg('sum')
   B   C
A       
1  7  14
2  6  10

聚合函數(shù)也可以傳入自定義的匿名函數(shù)。

# 匿名函數(shù)分組求和
df.groupby('A').agg(lambda x:sum(x))
   B   C   D
A           
1  7  14   7
2  6  10  12

多函數(shù)對多列

聚合函數(shù)可以是多個函數(shù)。聚合時,多個聚合函數(shù)會對每列進行計算,然后合并返回。聚合函數(shù)以列表的形式傳入。

# 全部列多函數(shù)聚合
df.groupby('A').agg(['sum','mean'])
    B        C        D     
  sum mean sum mean sum mean
A                           
1   7  3.5  14    7   7  3.5
2   6  3.0  10    5  12  6.0

聚合返回后的數(shù)據(jù)列名有兩層索引,第一層是聚合的列名,第二層是使用的聚合函數(shù)名。如果需要對返回的聚合函數(shù)名重命名,
需要在傳參時,傳入元組,第一個元素為聚合函數(shù)名,第二個元素為聚合函數(shù)。

# 聚合函數(shù)重命名
df.groupby('A').agg([('SUM','sum'),('MEAN','mean')])

    B        C        D     
  SUM MEAN SUM MEAN SUM MEAN
A                           
1   7  3.5  14    7   7  3.5
2   6  3.0  10    5  12  6.0

同樣,也可以傳入匿名函數(shù)。

# 匿名函數(shù)并重命名
df.groupby('A').agg([('SUM','sum'),('MAX',lambda x:max(x))])
    B       C       D    
  SUM MAX SUM MAX SUM MAX
A                        
1   7   4  14   8   7   5
2   6   3  10   9  12   8

如果需要對不同的列進行不同的聚合計算,則需要傳入字典的形式。

# 不同列不同聚合函數(shù)
df.groupby('A').agg({'B':['sum','mean'],'C':'mean'})
    B         C
  sum mean mean
A              
1   7  3.5    7
2   6  3.0    5

可以重命名聚合后的列名,注意只能對一列傳入一個聚合函數(shù)時有效。

# 聚合后重命名列名
df.groupby('A').agg(B_sum=('B','sum'),C_mean=('C','mean'))
   B_sum  C_mean
A               
1      7       7
2      6       5
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

  • 在日常數(shù)據(jù)分析時,經(jīng)常會遇到需要按列分組 (groupby) 的任務,如計算某公司各部門的人數(shù),計算各部門男女平均...
    心宇gxy閱讀 864評論 0 1
  • Pandas分組聚合 - 基礎 數(shù)據(jù)分析階段: 數(shù)據(jù)規(guī)整(清洗)階段后,下一階段就是 分組聚合 對數(shù)據(jù)集分組并對各...
    羋學僧閱讀 562評論 0 3
  • 一、數(shù)據(jù)分組 1.groupby簡介 groupby的運算核心為split-apply-combine,首先,數(shù)據(jù)...
    文嘉達_0da8閱讀 565評論 0 0
  • 數(shù)據(jù)的分組運算和聚合 在將數(shù)據(jù)集加載、融合、準備好之后,通常就是計算分組統(tǒng)計或?成透視表, pandas提供了?個...
    222AblackA閱讀 309評論 0 1
  • 最后一次更新日期: 2019/4/20 pandas是基于numpy的數(shù)據(jù)分析庫,提供一些更易用的數(shù)據(jù)模型和大量高...
    jiedawang閱讀 1,537評論 0 5

友情鏈接更多精彩內(nèi)容