Python自定义聚合函数merge与transform区别详解

作者:懒惰的星期六 时间:2022-09-14 11:45:30 

1.自定义聚合函数,结合agg使用

2. 同时使用多个聚合函数

3. 指定某一列使用某些聚合函数

4.merge与transform使用


import pandas as pd
 import numpy as np
 np.random.seed(1)
 dict_data = {
   'k1': ['a', 'b', 'c', 'd', 'a', 'b', 'c', 'd'],
   'k2': ['A', 'B', 'C', 'D', 'A', 'B', 'C', 'D'],
   'data1': np.random.randint(1,10,8),
   'data2': np.random.randint(1,10,8)
 }
 df = pd.DataFrame(dict_data)
 print('df=\n',df)
 df2 = df.groupby('k1').sum()
 # df2 = df.sum()
 print("df.groupby('k1').sum()\n",df2)

# 使用聚合函数
 def cus(df):
   return df.max()-df.min()
 # 默认列索引为列名。元组第0个元素‘Max',‘mu_cus'为自定义列名称,第一个元素为聚合函数名称
 print("使用聚合函数1\n",df.groupby('k1').agg(['sum',('Max','max'),('mu_cus',cus)]))
 # 制定某一列使用某个聚合函数, 元组不能用来重命名列名了,元组里面的函数,表示这一列将会执行的聚合函数
 print("使用聚合函数2\n",df.groupby('k1').agg({'data1':('min', 'max'),'data2':'min'}))

df3 = df.groupby('k1').sum().add_prefix('sum_')
 print('df3=\n',df3)
 # 如果不使用add_prefix('sum_'),那么在merge时候data1余data2列名相同,会被自动重命名
 print('merge=\n',pd.merge(df,df3,on='k1'))

transform_df = df.groupby('k1').transform(np.sum).add_prefix('sum_')
 print(transform_df)
 df[transform_df.columns]=transform_df # transform_df.columns Index(['sum_k2', 'sum_data1', 'sum_data2'], dtype='object')
 # df[transform_df.columns.values]=transform_df #等价,# transform_df.columns.values ['sum_k2', 'sum_data1', 'sum_data2']
print(df)  exit()

结果


df=
 k1 k2 data1 data2
0 a A   6   3
1 b B   9   5
2 c C   6   6
3 d D   1   3
4 a A   1   5
5 b B   2   3
6 c C   8   5
7 d D   7   8
df.groupby('k1').sum()
  data1 data2
k1      
a    7   8
b   11   8
c   14   11
d    8   11
使用聚合函数1
 data1      data2      
  sum Max mu_cus  sum Max mu_cus
k1                
a   7  6   5   8  5   2
b   11  9   7   8  5   2
c   14  8   2  11  6   1
d   8  7   6  11  8   5
使用聚合函数2
 data1   data2
  min max  min
k1        
a   1  6   3
b   2  9   3
c   6  8   5
d   1  7   3
df3=
  sum_data1 sum_data2
k1          
a      7     8
b     11     8
c     14     11
d      8     11
merge=
 k1 k2 data1 data2 sum_data1 sum_data2
0 a A   6   3     7     8
1 a A   1   5     7     8
2 b B   9   5     11     8
3 b B   2   3     11     8
4 c C   6   6     14     11
5 c C   8   5     14     11
6 d D   1   3     8     11
7 d D   7   8     8     11
sum_k2 sum_data1 sum_data2
0   AA     7     8
1   BB    11     8
2   CC    14    11
3   DD     8    11
4   AA     7     8
5   BB    11     8
6   CC    14    11
7   DD     8    11
k1 k2 data1 data2 sum_k2 sum_data1 sum_data2
0 a A   6   3   AA     7     8
1 b B   9   5   BB    11     8
2 c C   6   6   CC    14    11
3 d D   1   3   DD     8    11
4 a A   1   5   AA     7     8
5 b B   2   3   BB    11     8
6 c C   8   5   CC    14    11
7 d D   7   8   DD     8    11

Process finished with exit code 0

来源:https://www.cnblogs.com/sunupo/p/12941713.html

标签:Python,聚合,函数,merge,transform
0
投稿

猜你喜欢

  • python仿抖音表白神器

    2023-03-15 03:35:56
  • GridView自定义分页的四种存储过程

    2024-01-27 09:52:25
  • Python之csv文件从MySQL数据库导入导出的方法

    2023-08-09 04:45:10
  • Python List remove()实例用法详解

    2022-11-24 17:40:18
  • Python进度条tqdm的用法详解

    2022-09-03 00:27:35
  • python3使用mutagen进行音频元数据处理的方法

    2023-05-25 04:05:32
  • FrontPage XP设计教程1——站点初建与管理

    2008-10-11 12:13:00
  • pydev debugger: process 10341 is connecting无法debu的解决

    2022-11-02 12:04:00
  • JavaScript的私有成员

    2009-03-25 20:45:00
  • CSS布局之浮动(一)两列布局

    2008-08-18 21:24:00
  • python 返回列表中某个值的索引方法

    2021-05-25 21:44:13
  • jQuery页面滚动浮动层智能定位实例代码

    2024-04-22 22:22:16
  • Python socket模块方法实现详解

    2021-02-12 20:52:39
  • asp如何建立MYSQL数据库的连接?

    2009-11-26 20:30:00
  • python的pyecharts绘制各种图表详细(附代码)

    2021-12-29 16:51:13
  • Python使用xlrd模块操作Excel数据导入的方法

    2022-05-03 19:28:24
  • VUEJS实战之构建基础并渲染出列表(1)

    2024-05-29 22:14:46
  • 2008圣诞节网站特色Logo不完全点评

    2008-12-25 18:35:00
  • vue生成随机验证码的示例代码

    2023-07-02 16:57:09
  • DRF之请求与响应的实现

    2023-04-06 03:37:09
  • asp之家 网络编程 m.aspxhome.com