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的迭代器与生成器实例详解
Jul 16 Python
Django添加feeds功能的示例
Aug 07 Python
解决在Python编辑器pycharm中程序run正常debug错误的问题
Jan 17 Python
Python3 修改默认环境的方法
Feb 16 Python
浅谈PyQt5 的帮助文档查找方法,可以查看每个类的方法
Jun 25 Python
python:按行读入,排序然后输出的方法
Jul 20 Python
python 动态调用函数实例解析
Oct 21 Python
python3 实现函数写文件路径的正确方法
Nov 27 Python
解决Django中checkbox复选框的传值问题
Mar 31 Python
python中requests模拟登录的三种方式(携带cookie/session进行请求网站)
Nov 17 Python
Python用Jira库来操作Jira
Dec 28 Python
pycharm部署django项目到云服务器的详细流程
Jun 29 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
php 删除cookie方法详解
2014/12/01 PHP
php文件系统处理方法小结
2016/05/23 PHP
Windows2003下php5.4安装配置教程(IIS)
2016/06/30 PHP
PHP常用的三种设计模式汇总
2016/08/28 PHP
fckeditor 获取文本框值的实现代码
2009/02/09 Javascript
Bootstrap轮播插件使用代码
2016/10/11 Javascript
小程序开发实战:实现九宫格界面的导航的代码实现
2017/01/19 Javascript
Vue.js 的移动端组件库mint-ui实现无限滚动加载更多的方法
2017/12/23 Javascript
在vue中使用v-bind:class的选项卡方法
2018/09/27 Javascript
Vue核心概念Getter的使用方法
2019/01/18 Javascript
vue中利用simplemde实现markdown编辑器(增加图片上传功能)
2019/04/29 Javascript
使用Karma做vue组件单元测试的实现
2020/01/16 Javascript
[10:28]2018DOTA2国际邀请赛寻真——VGJ.S寻梦之路
2018/08/15 DOTA
Python实现文件复制删除
2016/04/19 Python
详解python 字符串和日期之间转换 StringAndDate
2017/05/04 Python
Python入门_浅谈字符串的分片与索引、字符串的方法
2017/05/16 Python
Python基于tkinter模块实现的改名小工具示例
2017/07/27 Python
浅谈用Python实现一个大数据搜索引擎
2017/11/28 Python
Tensorflow中使用tfrecord方式读取数据的方法
2018/06/19 Python
python-str,list,set间的转换实例
2018/06/27 Python
Python将8位的图片转为24位的图片实现方法
2018/10/24 Python
Python os.rename() 重命名目录和文件的示例
2018/10/25 Python
浅谈python新式类和旧式类区别
2019/04/26 Python
浅谈django url请求与数据库连接池的共享问题
2019/08/29 Python
tensorflow tf.train.batch之数据批量读取方式
2020/01/20 Python
Python3.7黑帽编程之病毒篇(基础篇)
2020/02/04 Python
一款简洁的纯css3代码实现的动画导航
2014/10/31 HTML / CSS
分享一个页面平滑滚动小技巧(推荐)
2019/10/23 HTML / CSS
Etam德国:内衣精品店
2019/08/25 全球购物
介绍一下如何优化MySql
2016/12/20 面试题
会计求职信范文
2014/05/24 职场文书
2014年团委工作总结
2014/11/13 职场文书
自考生自我评价
2019/06/21 职场文书
PHP策略模式写法
2021/04/01 PHP
OpenCV全景图像拼接的实现示例
2021/06/05 Python
css实现左上角飘带效果的完整代码
2022/03/18 HTML / CSS