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


Posted in Python onMay 26, 2020

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python实现的二叉树算法和kmp算法实例
Apr 25 Python
python获取图片颜色信息的方法
Mar 18 Python
Python中的rjust()方法使用详解
May 19 Python
浅谈python中的getattr函数 hasattr函数
Jun 14 Python
Python中多线程的创建及基本调用方法
Jul 08 Python
使用 Python 快速实现 HTTP 和 FTP 服务器的方法
Jul 22 Python
利用pytorch实现对CIFAR-10数据集的分类
Jan 14 Python
浅谈对python中if、elif、else的误解
Aug 20 Python
利用Python函数实现一个万历表完整示例
Jan 23 Python
Python生成九宫格图片的示例代码
Apr 14 Python
Python自动化工具之实现Excel转Markdown表格
Apr 08 Python
详解Golang如何实现支持随机删除元素的堆
Sep 23 Python
Python Tornado实现WEB服务器Socket服务器共存并实现交互的方法
May 26 #Python
tensorflow实现从.ckpt文件中读取任意变量
May 26 #Python
打印tensorflow恢复模型中所有变量与操作节点方式
May 26 #Python
tensorflow模型的save与restore,及checkpoint中读取变量方式
May 26 #Python
tensorflow从ckpt和从.pb文件读取变量的值方式
May 26 #Python
Pytorch转keras的有效方法,以FlowNet为例讲解
May 26 #Python
Django+Celery实现动态配置定时任务的方法示例
May 26 #Python
You might like
全国FM电台频率大全 - 7 吉林省
2020/03/11 无线电
福利彩票幸运号码自动生成器
2006/10/09 PHP
强烈声明: 不要使用(include/require)_once
2013/06/06 PHP
使用PHP导出Word文档的原理和实例
2013/10/21 PHP
PHP大转盘中奖概率算法实例
2014/10/21 PHP
php实现在站点里面添加邮件发送的功能
2020/04/28 PHP
Web版彷 Visual Studio 2003 颜色选择器
2007/01/09 Javascript
Js切换功能的简单方法
2010/11/23 Javascript
解决jQuery动态获取手机屏幕高和宽的问题
2014/05/07 Javascript
js鼠标点击图片切换效果代码分享
2015/08/26 Javascript
基于 Node.js 实现前后端分离
2016/04/23 Javascript
深入浅析JavaScript中的3DES
2016/08/24 Javascript
xmlplus组件设计系列之分隔框(DividedBox)(8)
2017/05/02 Javascript
使用jQuery实现简单的tab框实例
2017/08/22 jQuery
基于JavaScript中字符串的match与replace方法(详解)
2017/12/04 Javascript
ES6 系列之 WeakMap的使用示例
2018/08/06 Javascript
详解基于React.js和Node.js的SSR实现方案
2019/03/21 Javascript
[01:27]DOTA2电竞之夜 今夜共饮庆功酒
2014/08/02 DOTA
Pycharm学习教程(5) Python快捷键相关设置
2017/05/03 Python
python3.6 +tkinter GUI编程 实现界面化的文本处理工具(推荐)
2017/12/20 Python
python求最大值,不使用内置函数的实现方法
2019/07/09 Python
在notepad++中实现直接运行python代码
2019/12/18 Python
Python实现手机号自动判断男女性别(实例解析)
2019/12/22 Python
pytorch获取模型某一层参数名及参数值方式
2019/12/30 Python
python 计算方位角实例(根据两点的坐标计算)
2020/01/17 Python
js实现移动端H5页面手指滑动刻度尺功能
2017/11/16 HTML / CSS
html5中svg canvas和图片之间相互转化思路代码
2014/01/24 HTML / CSS
浅谈基于Canvas的手绘风格图形库Rough.js
2018/03/19 HTML / CSS
一道Delphi上机题
2012/06/04 面试题
环卫个人总结
2015/03/03 职场文书
承兑汇票延期证明
2015/06/23 职场文书
毕业班工作总结
2015/08/10 职场文书
党员干部学习三严三实心得体会
2016/01/05 职场文书
护士业务学习心得体会
2016/01/25 职场文书
Mysql案例刨析事务隔离级别
2021/09/25 MySQL
Linux中sftp常用命令整理
2022/06/28 Servers