16.Pandas实现groupBy分组统计

简单介绍

类似Sql:
select city,max(temperature) from city_weather group by city;
groupby:先对数据分组,然后在每个分组上应用聚合函数,转换函数
本次演示

  1. 分组使用聚合函数做数据统计
  2. 遍历groupby的结果理解执行流程
  3. 实例分组探索天气数据
import pandas as pd
import numpy as np

df = pd.DataFrame({
    'A': ['foo', 'bar', 'foo', 'bar', 'foo', 'bar', 'foo', 'foo'],
    'B': ['one', 'one', 'two', 'three', 'two', 'two', 'one', 'three'],
    'C': np.random.randn(8),
    'D': np.random.randn(8)
})
print(df)

在这里插入图片描述

分组使用聚合函数做数据统计

1.单个列groupby,查询所有列的统计

# 1.groupby中A变成了数据的索引列
# 2.因为要统计sum,但B列不是数字,所以被自动忽略掉
print(df.groupby('A').sum())

在这里插入图片描述

2.多个列groupby,查询所有数据列的统计

# (A,B)成对变成了二级索引
print(df.groupby(['A', 'B']).mean())
print("*" * 32)
print(df.groupby(['A', 'B'], as_index=False).mean())

在这里插入图片描述

3.同时查看多种数据统计

在这里插入图片描述

4.查看单列的结果数据统计

在这里插入图片描述

5.不同列使用不同的聚合函数

在这里插入图片描述

遍历groupby的结果理解执行流程

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

实例分组探索天气数据

数据整理

import pandas as pd
fpath = "../data/tianqi.csv"
df = pd.read_csv(fpath)
# 替换掉温度的后缀
df.loc[:, "bWenDu"] = df["bWenDu"].str.replace("°C", "").astype('int32')
df.loc[:, "yWenDu"] = df["yWenDu"].str.replace("°C", "").astype('int32')
print(df.head())

在这里插入图片描述

# 新增一列为月份
df['mouth'] = df['ymd'].str[:7]
print(df.head())

在这里插入图片描述

查看每个月的最高温度

data = df.groupby('mouth')['bWenDu'].max()
print(data)
type(data)
print(type(df.groupby('mouth')))

在这里插入图片描述

查看每个月的最高温度、最低温度、平均空气质量指数

group_data = df.groupby('mouth').agg({"bWenDu": np.max, "yWenDu": np.min, "aqi": np.mean})
print(group_data)

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值