多种分组聚合

import pandas as pd
import numpy as np
import matplotlib
import matplotlib.pyplot as plt
#这两个参数的默认设置都是False  用于将数据对齐展示
pd.set_option('display.unicode.ambiguous_as_wide', True)
pd.set_option('display.unicode.east_asian_width', True)
data = pd.read_csv('../dataset/5/5.4/data.csv')
data.head()

 

 

#单字段分组
print(data.groupby('省份')['月消费(元)'].agg('sum'))
print('============================================')
print(data.groupby('省份')['月消费(元)'].sum())
print('==============================================')
print(data.groupby('省份').agg({'月消费(元)':'sum'}))
#前面三个效果相同

print('===========================================')
print(data.groupby('省份')['月消费(元)'].agg({'费用':'sum'}))

#这是为了定义一个列名,最后使用reset_index()将多重索引变成一个

#多字段分组,单字段聚合
print(data.groupby(['省份','手机品牌'])['月消费(元)'].agg({'费用':'sum'}))  #reset_index()

 

#多字段分组,多字段聚合
print(data.groupby(['省份','手机品牌'])['月消费(元)','月流量(M)'].agg('sum').reset_index().head(10))
print('=============================')

#多字段分组,多字段聚合,多个聚合函数
print(data.groupby(['省份','手机品牌'])['月消费(元)','月流量(M)'].agg({'总计':'sum','平均':'mean'}).head(10))
print('=========================')
print(data.groupby(['省份','手机品牌'])['月消费(元)','月流量(M)'].agg(['sum','mean']).head(10))

#多个字段各自使用自己的函数

gp = data.groupby(['省份','手机品牌']).agg({
    '月消费(元)':{'求和':'sum','平均值':'mean','最小':'min'},
    '月流量(M)':{'求和':'sum','平均值':'mean','最小':'min'}
}).head(10)
gp

 

 

# index0 =gp.columns.get_level_values(0)
# index1 =gp.columns.get_level_values(1)
# print(index0)
# print(index1)
# gp.columns = index0 + '_' +index1
gp.reset_index()

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

半两风

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值