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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年09月21日
2024年09月21日
- 《少女前线2:追放》项目组将裁员 官方:进一步优化组织结构
- 陈慧琳.2002-闪亮每一天新歌+精选2CD【正东】【WAV+CUE】
- 袁培华.1992-有缘【歌林】【WAV+CUE】
- 王瑞霞.1996-是我太软心【名冠】【WAV+CUE】
- 《谭维维 30首经典流行歌曲精选辑 2CD》[WAV/分轨][1.1GB]
- 《赵传 出道三十年全新大碟 你过得还好吗》[WAV/分轨][460MB]
- 《发烧四大天王 磁性男声HiFi发烧碟 2CD》[WAV/分轨][1GB]
- 黑神话悟空上品鼠司空精魄获取方法一览|上品鼠司空精魄收集攻略
- 《真三国无双:起源》新情报将于9月26日公开,实机演示亮相!
- 黑神话悟空上品鼠禁卫精魄获取方法一览|上品鼠禁卫精魄收集攻略
- 优美的旋律至真的情怀《品茶轻音乐·极品典藏Vol.1CD1》[WAV+CUE]
- 曾嵘《峥嵘岁月DSD(试音碟)》WAV+CUE
- 小提琴天碟AlfredoCampoli坎波利-贝多芬D大调小提琴协奏曲与普罗米修斯作品选FLAC
- 博主称本周游戏业内动荡无比:高价PS5 Pro、Xbox裁员等
- 米哈游也搞AI?米哈游AI大模型Glossa完成备案