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=

",df)

df2 = df.groupby("k1").sum()

# df2 = df.sum()

print("df.groupby("k1").sum()

",df2)

# 使用聚合函数

def cus(df):

return df.max()-df.min()

# 默认列索引为列名。元组第0个元素‘Max",‘mu_cus"为自定义列名称,第一个元素为聚合函数名称

print("使用聚合函数1

",df.groupby("k1").agg(["sum",("Max","max"),("mu_cus",cus)]))

# 制定某一列使用某个聚合函数, 元组不能用来重命名列名了,元组里面的函数,表示这一列将会执行的聚合函数

print("使用聚合函数2

",df.groupby("k1").agg({"data1":("min", "max"),"data2":"min"}))

df3 = df.groupby("k1").sum().add_prefix("sum_")

print("df3=

",df3)

# 如果不使用add_prefix("sum_"),那么在merge时候data1余data2列名相同,会被自动重命名

print("merge=

",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

pythontransform详解_Python自定义聚合函数merge与transform区别详解相关推荐

  1. SqlServer自定义聚合函数

    sqlserver2017版本包括以上的可以使用string_agg(字段,',')函数 sqlserver查询版本: select @@version Sql Server自定义聚合函数详细bai步 ...

  2. oracle 自定义 聚合函数

    Oracle自定义聚合函数实现字符串连接的聚合 create or replace type string_sum_obj as object (  --聚合函数的实质就是一个对象       sum ...

  3. Presto如何开发自定义聚合函数

    (一)先了解一下什么是自定义聚合函数 其实就是根据你自己的业务去进行定义你自己想要实现的方法,比如说Mysql中的sum() 方法,就是求某个字段的累加之和,那么你就可以自己实现自己的 比如说 add ...

  4. pandas使用教程:apply函数、聚合函数agg和transform

    文章目录 apply函数调用 apply函数描述性统计 apply函数lambda自定义 聚合函数aggregate/agg 用字典实现聚合 transform函数 多函数 Transform 重置索 ...

  5. python def函数报错详解_python自定义函数def的应用详解

    这篇文章主要介绍了python自定义函数def的应用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧 这里是三岁,来和大家唠唠 ...

  6. python scatter参数详解_Python 中 scatter 函数参数及用法详解

    Python 中 scatter 函数参数及用法详解 Python 中 scatter 函数参数及用法详解 这里有新鲜出炉的 Python 教程, 程序狗速度看过来! Python 编程语言 Pyth ...

  7. oracle sum详解,oracle sum()聚合函数

    原文链接:https://blog.csdn.net/cizatu5130/article/details/100291347 oracle sum()聚合函数 2016-05-13 20:08:00 ...

  8. 【大数据】Presto开发自定义聚合函数

    Presto 在交互式查询任务中担当着重要的职责.随着越来越多的人开始使用 SQL 在 Presto 上分析数据,我们发现需要将一些业务逻辑开发成类似 Hive 中的 UDF,提高 SQL 使用人员的 ...

  9. SQL SERVER 2005允许自定义聚合函数

    不多说了,说明后面是完整的代码,用来将字符串型的字段的各行的值拼成一个大字符串,也就是通常所说的Concat 例如有如下表dict  ID  NAME  CATEGORY  1 RED  COLOR  ...

最新文章

  1. vue-ueditor 后端配置项没有正常加载_揭秘Gannt后端集成问题该如何解决
  2. Python基础教程:列表(list)切片详细操作
  3. VTK:可视化之HanoiInitial
  4. TabActivity 切换到后台遇到的问题
  5. synchronized(九)
  6. 听说年底这些公司在裁员?是不是真的......
  7. 大话数据结构第四章栈的基本概念与出栈入栈操作
  8. [转]如何使用WinPE硬盘安装Windows XP
  9. 震惊:selenium竟然不是自动化测试工具
  10. linux加速度传感器校准,加速度传感器校准方法及装置与流程
  11. 在MVC中使用泛型仓储模式和依赖注入实现增删查改
  12. python简单文件服务器
  13. 大型文件传输慢、传输中断怎么办?
  14. 亚马逊多账号操作如何判断关联
  15. 前段JavaScript学习---狂神说java笔记
  16. Unity一般工程升级到HDRP
  17. 1051 复数乘法(JAVA)
  18. 13计算机组装,舞阳中专2012-13年度《计算机组装与维修》期中考试试题
  19. JavaScript :调用浏览器摄像头 API
  20. 关于maxIdle ,MaxActive,maxWait介绍

热门文章

  1. Ubuntu18.04开机自启动脚本(systemctl方式)
  2. pulseaudio之pacmd命令
  3. 结构体第一个成员是结构体,则为父结构体首地址demo(六)
  4. Android抓包方法(二) 之Tcpdump命令+Wireshark
  5. iwlist/iwconfig/iw命令
  6. Android开发重要参考资料
  7. android 不生成odex文件方法
  8. android之数组排序
  9. easyui crud java_轻松学习jQuery插件EasyUI EasyUI创建CRUD应用
  10. 已解决:home目录下ubuntu文件夹被误删。。。。