色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Python自定義聚合函數merge與transform區別詳解

瀏覽:37日期:2022-07-24 15:13:59

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('使用聚合函數1n',df.groupby(’k1’).agg([’sum’,(’Max’,’max’),(’mu_cus’,cus)])) # 制定某一列使用某個聚合函數, 元組不能用來重命名列名了,元組里面的函數,表示這一列將會執行的聚合函數 print('使用聚合函數2n',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 data20 a A 6 31 b B 9 52 c C 6 63 d D 1 34 a A 1 55 b B 2 36 c C 8 57 d D 7 8df.groupby(’k1’).sum() data1 data2k1 a 7 8b 11 8c 14 11d 8 11使用聚合函數1 data1 data2 sum Max mu_cus sum Max mu_cusk1 a 7 6 5 8 5 2b 11 9 7 8 5 2c 14 8 2 11 6 1d 8 7 6 11 8 5使用聚合函數2 data1 data2 min max mink1a 1 6 3b 2 9 3c 6 8 5d 1 7 3df3= sum_data1 sum_data2k1 a 7 8b 11 8c 14 11d 8 11merge= k1 k2 data1 data2 sum_data1 sum_data20 a A 6 3 7 81 a A 1 5 7 82 b B 9 5 11 83 b B 2 3 11 84 c C 6 6 14 115 c C 8 5 14 116 d D 1 3 8 117 d D 7 8 8 11 sum_k2 sum_data1 sum_data20 AA 7 81 BB 11 82 CC 14 113 DD 8 114 AA 7 85 BB 11 86 CC 14 117 DD 8 11 k1 k2 data1 data2 sum_k2 sum_data1 sum_data20 a A 6 3 AA 7 81 b B 9 5 BB 11 82 c C 6 6 CC 14 113 d D 1 3 DD 8 114 a A 1 5 AA 7 85 b B 2 3 BB 11 86 c C 8 5 CC 14 117 d D 7 8 DD 8 11Process finished with exit code 0

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 国产孕妇孕交视频在线观看 | a级毛片免费播放 | 一级片免费观看 | 天堂精品高清1区2区3区 | 日韩 国产 欧美视频一区二区三区 | 王朝影院一区二区三区入口 | 国产成人最新毛片基地 | 成 人 a v黄 色 | 亚洲综合一区二区精品久久 | 美女视频黄a全部免费专区一 | 久久久久久亚洲精品影院 | 精品日韩在线视频一区二区三区 | 亚洲 欧美 成人日韩 | 本道久久综合88全国最大色 | 久久视频这里只精品3国产 久久视频这里只有精品 | 久草在线 | 国产高清在线看 | 国产欧美日韩视频免费61794 | 欧美黄视频在线观看 | 国产精品久久久久久久久 | 波多久久夜色精品国产 | 一级国产交换配乱淫 | 午夜三级在线 | 国产三级播放 | 国产日韩精品欧美一区 | 久久亚洲综合中文字幕 | 亚洲成a v人片在线观看 | 男人把女人桶到喷白浆的视频 | 美女视频网站永久免费观看软件 | 日韩中文字幕在线观看 | 国产亚洲欧美在线人成aaaa | 窝窝午夜看片七次郎青草视频 | 女人张开腿让男人捅爽 | 成人午夜视频在线观 | 亚洲精品98久久久久久中文字幕 | 久99re视频9在线观看 | 欧美日韩在线视频不卡一区二区三区 | 国产免费亚洲 | 一级片a| 曰本毛片va看到爽不卡 | 一区二区三区视频观看 |