人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

python pandas分組聚合詳細(xì)

發(fā)布日期:2022-01-31 13:17 | 文章來(lái)源:站長(zhǎng)之家

python pandas分組聚合

1、環(huán)境

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

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

2、分組

import pandas as pd
import numpy as np
pd.set_option('display.notebook_repr_html',False)
# 數(shù)據(jù)準(zhǔn)備
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

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

元組的第一個(gè)元素是分組值,第二個(gè)元素是對(duì)應(yīng)的分組數(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'>

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

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

3、序列分組

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

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

4、多列分組

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

# 數(shù)據(jù)準(zhǔn)備
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ìn)行分組,然后求和。

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

5、索引分組

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

# 數(shù)據(jù)準(zhǔn)備
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è)置參數(shù)level=0。

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

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

# 數(shù)據(jù)準(zhǔn)備
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 
13  4
 4  7
23  2
 3  9

設(shè)置level參數(shù),如需要根據(jù)第一層索引,即id1進(jìn)行分組,可以設(shè)置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

7、聚合

分組后一般會(huì)進(jìn)行聚合操作,用agg方法進(jìn)行聚合。

# 數(shù)據(jù)準(zhǔn)備
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

8、單函數(shù)對(duì)多列

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

# 對(duì)所有列分組求和
df.groupby('A').agg('sum')

BCD
A  
1  7  147
2  6  10  12

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

# 對(duì)指定列分組求和
df.groupby('A')[['B','C']].agg('sum')

BC
A 
1  7  14
2  6  10

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

# 匿名函數(shù)分組求和
df.groupby('A').agg(lambda x:sum(x))

  BCD
A  
1  7  147
2  6  10  12

9、多函數(shù)對(duì)多列

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

# 全部列多函數(shù)聚合
df.groupby('A').agg(['sum','mean'])

 B  C  D  
  sum mean sum mean sum mean
A
17  3.5  14 77  3.5
26  3.0  10 5  12  6.0

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

# 聚合函數(shù)重命名
df.groupby('A').agg([('SUM','sum'),('MEAN','mean')])
 B  C  D  
  SUM MEAN SUM MEAN SUM MEAN
A
17  3.5  14 77  3.5
26  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
174  14875
263  109  128

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

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

 BC
  sum mean mean
A  
17  3.5 7
26  3.0 5

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

# 聚合后重命名列名
df.groupby('A').agg(B_sum=('B','sum'),C_mean=('C','mean'))

B_sum  C_mean
A
17 7
26 5

到此這篇關(guān)于python pandas分組聚合詳細(xì)的文章就介紹到這了,更多相關(guān)python pandas分組聚合內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

美國(guó)穩(wěn)定服務(wù)器

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開(kāi)通

自選配置、實(shí)時(shí)開(kāi)通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問(wèn)服務(wù)

1對(duì)1客戶咨詢顧問(wèn)

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部