df.groupby()方法使用在查询中用到的筛选条件函数对 数据进行分组

这里举的例子是:

  • 按姓名首字母分组
python 复制代码
df.groupby(df.name.str[0])
  • 按A及B、其他团队分组
python 复制代码
df.groupby(df.team.isin(['A','B']))
  • 按姓名第一个字母和第二个字母分组
python 复制代码
df.groupby([df.name.str[0], df.name.str[1]])
  • 按日期和小时分组
python 复制代码
df.groupby([df.time.date, df.time.hour])

这些示例展示了如何使用 groupby 按不同的列值进行分组,每个分组的规则都是基于字符串的处理、布尔值判断或者日期时间的提取。下面我逐一解释每个示例:

1. 按姓名首字母分组

python 复制代码
df.groupby(df.name.str[0])
  • 作用 :这个 groupby 操作通过提取 name 列的每个值的首字母来进行分组。

  • df.name.str[0] 会提取 name 列中每个字符串的第一个字符(即首字母),并基于这些首字母来进行分组。

    假设 name 列的数据是:['Alice', 'Bob', 'Charlie', 'David', 'Eve'],那么 df.name.str[0] 将返回:['A', 'B', 'C', 'D', 'E']

  • 示例

    python 复制代码
    df = pd.DataFrame({
        'name': ['Alice', 'Bob', 'Charlie', 'David', 'Eve'],
        'age': [25, 30, 35, 40, 45]
    })
    
    result = df.groupby(df.name.str[0]).sum()
    print(result)

    输出:

    复制代码
           age
    name      
    A       25
    B       30
    C       35
    D       40
    E       45

2. 按 A及B、其他团队分组

python 复制代码
df.groupby(df.team.isin(['A', 'B']))
  • 作用 :这个 groupby 操作通过 team 列判断每个值是否属于 'A''B' 团队来进行分组。

  • df.team.isin(['A', 'B']) 返回一个布尔系列,对于每个 team 列中的值,如果它是 'A''B',则返回 True,否则返回 False

    假设 team 列的数据是:['A', 'B', 'C', 'A', 'D'],那么 df.team.isin(['A', 'B']) 将返回:[True, True, False, True, False]

  • 示例

    python 复制代码
    df = pd.DataFrame({
        'team': ['A', 'B', 'C', 'A', 'D'],
        'score': [80, 90, 85, 95, 70]
    })
    
    result = df.groupby(df.team.isin(['A', 'B'])).sum()
    print(result)

    输出:

    复制代码
           score
    team        
    False    155
    True     265
    • True 表示 AB 团队的分组,False 表示其他团队的分组。

3. 按姓名第一个字母和第二个字母分组

python 复制代码
df.groupby([df.name.str[0], df.name.str[1]])
  • 作用 :这个 groupby 操作通过提取 name 列中每个值的前两个字母来进行分组。

  • df.name.str[0] 提取第一个字母,df.name.str[1] 提取第二个字母。两个字母作为分组的依据。

    假设 name 列的数据是:['Alice', 'Alex', 'Bob', 'Charlie', 'Eve'],那么 df.name.str[0] 返回 ['A', 'A', 'B', 'C', 'E']df.name.str[1] 返回 ['l', 'l', 'o', 'h', 'v']

  • 示例

    python 复制代码
    df = pd.DataFrame({
        'name': ['Alice', 'Alex', 'Bob', 'Charlie', 'Eve'],
        'age': [25, 30, 35, 40, 45]
    })
    
    result = df.groupby([df.name.str[0], df.name.str[1]]).sum()
    print(result)

    输出:

    复制代码
               age
    name name      
    A    l       55
    B    o       35
    C    h       40
    E    v       45
    • 这里每个分组的标识由姓名的前两个字母组成。

4. 按日期和小时分组

python 复制代码
df.groupby([df.time.date, df.time.hour])
  • 作用 :这个 groupby 操作首先提取 time 列中的日期部分(去掉时间),然后提取小时部分(24小时制)。

  • df.time.date 提取日期部分,df.time.hour 提取小时部分。这样你可以按照日期和小时来对数据进行分组。

    假设 time 列的数据是:['2025-01-01 10:20:00', '2025-01-01 11:30:00', '2025-01-02 10:45:00'],那么 df.time.date 会返回:['2025-01-01', '2025-01-01', '2025-01-02']df.time.hour 会返回:[10, 11, 10]

  • 示例

python 复制代码
import pandas as pd

# 创建DataFrame
df = pd.DataFrame({
    'time': pd.to_datetime(['2025-01-01 10:20:00', '2025-01-01 11:30:00', '2025-01-02 10:45:00']),
    'value': [100, 200, 300]
})
print(df,'\n\n')

# 按日期和小时分组,并对value列进行求和
result = df.groupby([df.time.dt.date, df.time.dt.hour])['value'].sum()

print(result)

输出:

  • 这里的数据是按照日期和小时分组的,结果是每个日期和小时组合下的 value 总和。

总结

  • 按姓名首字母分组:通过字符串的第一个字母来分组。
  • 按 A及B、其他团队分组 :通过判断某个列的值是否属于特定集合(例如 'A''B')来分组。
  • 按姓名的前两个字母分组:通过字符串的前两个字母来分组。
  • 按日期和小时分组 :通过日期和小时来分组,适用于处理 datetime 类型数据。

这些方法展示了 groupby 操作的灵活性,可以根据不同的条件对数据进行分组和聚合处理。

相关推荐
阿里云大数据AI技术6 分钟前
OpenSearch 视频 RAG 实践
数据库·人工智能·llm
遇雪长安10 分钟前
差分定位技术:原理、分类与应用场景
算法·分类·数据挖掘·rtk·差分定位
XMAIPC_Robot19 分钟前
基于ARM+FPGA的光栅尺精密位移加速度测试解决方案
arm开发·人工智能·fpga开发·自动化·边缘计算
加油吧zkf28 分钟前
YOLO目标检测数据集类别:分类与应用
人工智能·计算机视觉·目标跟踪
是Dream呀40 分钟前
基于连接感知的实时困倦分类图神经网络
神经网络·分类·数据挖掘
Blossom.1181 小时前
机器学习在智能制造业中的应用:质量检测与设备故障预测
人工智能·深度学习·神经网络·机器学习·机器人·tensorflow·sklearn
天天扭码1 小时前
AI时代,前端如何处理大模型返回的多模态数据?
前端·人工智能·面试
难受啊马飞2.01 小时前
如何判断 AI 将优先自动化哪些任务?
运维·人工智能·ai·语言模型·程序员·大模型·大模型学习
顺丰同城前端技术团队1 小时前
掌握未来:构建专属领域的大模型与私有知识库——从部署到微调的全面指南
人工智能·deepseek
许泽宇的技术分享1 小时前
用.NET9+Blazor+Semantic Kernel,打造企业级AI知识库和智能体平台——AntSK深度解读
人工智能