0

0

基于分组和条件添加新列:Pandas教程

碧海醫心

碧海醫心

发布时间:2025-08-07 21:02:32

|

1062人浏览过

|

来源于php中文网

原创

基于分组和条件添加新列:pandas教程

本文详细介绍了如何使用 Pandas 在 DataFrame 中基于分组和条件添加新列。通过 groupby()、apply()、sort_values()、shift() 和 cumsum() 等函数的组合使用,可以实现复杂的数据转换和列生成。本文提供清晰的代码示例和详细的步骤解释,帮助读者理解并掌握该技巧,从而解决实际数据处理中的类似问题。

在数据分析和处理中,经常需要在 Pandas DataFrame 中基于现有列进行分组,并根据分组内的条件计算新列的值。本教程将详细介绍如何使用 Pandas 实现这一目标,并通过一个具体的例子进行说明。

示例数据

首先,我们创建一个示例 DataFrame,用于演示如何添加新列:

import pandas as pd
import numpy as np

data = {
    'id': [1, 2, 3, 4, 5, 6, 7],
    'date': ['2019-02-01', '2019-02-10', '2019-02-25', '2019-03-05', '2019-03-16', '2019-04-05', '2019-05-15'],
    'date_difference': [None, 9, 15, 11, 10, 19, 40],
    'number': [1, 0, 1, 0, 0, 0, 0],
    'text': ['A', 'A', 'A', 'A', 'A', 'B', 'B']
}

df = pd.DataFrame(data)
print(df)

问题描述

我们的目标是基于 text 列进行分组,并根据 number 列的值生成一个新的列 test。对于每个分组,test 列的值的计算规则如下:

  1. 首先按照 date 列降序排列组内数据。
  2. 如果 number 列的值为 0,则 test 列的值从 1 开始递增。
  3. 如果在 number 列中出现 1,则后续的 test 列的值在之前的最大值基础上保持不变。
  4. 如果分组内没有 1,则 test 列的值始终为 1。

解决方案

以下代码展示了如何使用 Pandas 实现上述逻辑:

Type
Type

生成草稿,转换文本,获得写作帮助-等等。

下载
import pandas as pd


data = {
    'id': [1, 2, 3, 4, 5, 6, 7],
    'date': ['2019-02-01', '2019-02-10', '2019-02-25', '2019-03-05', '2019-03-16', '2019-04-05', '2019-05-15'],
    'date_difference': [None, 9, 15, 11, 10, 19, 40],
    'number': [1, 0, 1, 0, 0, 0, 0],
    'text': ['A', 'A', 'A', 'A', 'A', 'B', 'B']
}

df = pd.DataFrame(data)

out = df.assign(
    # We assign the following values to the series name "test"
    test=df
    # Group on "text" -- if we grouped on ["text", "number"] we wouldn't see different numbers within the groups.
    .groupby("text")
    # Apply a chain of methods to the group (a pd.DataFrame).
    .apply(
        lambda g: (
            # We sort "date" in descending order as you mention this partially controls the step size.
            g.sort_values(by="date", ascending=False)
            # We shift "number" forward one period with a fill_value of 1 for any newly introduced nulls.
            .number.shift(periods=1, fill_value=1)
            # Cumulatively sum the shifted "number" values
            .cumsum()
        )
        # This will result in the new series, albeit sorted by descending "date".
    )
    # Drop the "text" level of the new multi-index.
    .droplevel("text")
    # The assign method acts as join, rearranging the newly created series to match the index of `df`.
)
print(out)

代码解释:

  1. df.groupby("text"): 首先,我们使用 groupby() 函数按照 text 列对 DataFrame 进行分组。
  2. .apply(lambda g: ...): 然后,我们使用 apply() 函数对每个分组应用一个自定义的 lambda 函数。
  3. g.sort_values(by="date", ascending=False): 在 lambda 函数内部,我们首先按照 date 列降序排列每个分组。
  4. .number.shift(periods=1, fill_value=1): 使用 shift() 函数将 number 列的值向前移动一位。fill_value=1 用于填充移动后产生的缺失值,保证第一行数据的值为 1。
  5. .cumsum(): 使用 cumsum() 函数计算移动后的 number 列的累积和,从而得到 test 列的值。
  6. .droplevel("text"): 删除分组后产生的MultiIndex,确保结果与原DataFrame的索引对齐。
  7. df.assign(test=...): 最后,使用 assign() 函数将新生成的 test 列添加到原始 DataFrame 中。

总结

本教程介绍了如何使用 Pandas 在 DataFrame 中基于分组和条件添加新列。通过 groupby()、apply()、sort_values()、shift() 和 cumsum() 等函数的组合使用,可以灵活地实现复杂的数据转换和列生成。理解并掌握这些技巧,可以帮助您更高效地进行数据分析和处理。

注意事项:

  • 在实际应用中,需要根据具体的数据和需求调整代码。
  • 理解每个函数的具体作用和参数,才能更好地应用它们。
  • 可以使用其他 Pandas 函数和方法来进一步优化代码,例如 fillna()、where() 等。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python 时间序列分析与预测
Python 时间序列分析与预测

本专题专注讲解 Python 在时间序列数据处理与预测建模中的实战技巧,涵盖时间索引处理、周期性与趋势分解、平稳性检测、ARIMA/SARIMA 模型构建、预测误差评估,以及基于实际业务场景的时间序列项目实操,帮助学习者掌握从数据预处理到模型预测的完整时序分析能力。

65

2025.12.04

lambda表达式
lambda表达式

Lambda表达式是一种匿名函数的简洁表示方式,它可以在需要函数作为参数的地方使用,并提供了一种更简洁、更灵活的编码方式,其语法为“lambda 参数列表: 表达式”,参数列表是函数的参数,可以包含一个或多个参数,用逗号分隔,表达式是函数的执行体,用于定义函数的具体操作。本专题为大家提供lambda表达式相关的文章、下载、课程内容,供大家免费下载体验。

208

2023.09.15

python lambda函数
python lambda函数

本专题整合了python lambda函数用法详解,阅读专题下面的文章了解更多详细内容。

191

2025.11.08

Python lambda详解
Python lambda详解

本专题整合了Python lambda函数相关教程,阅读下面的文章了解更多详细内容。

55

2026.01.05

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

2

2026.01.29

java配置环境变量教程合集
java配置环境变量教程合集

本专题整合了java配置环境变量设置、步骤、安装jdk、避免冲突等等相关内容,阅读专题下面的文章了解更多详细操作。

2

2026.01.29

java成品学习网站推荐大全
java成品学习网站推荐大全

本专题整合了java成品网站、在线成品网站源码、源码入口等等相关内容,阅读专题下面的文章了解更多详细推荐内容。

0

2026.01.29

Java字符串处理使用教程合集
Java字符串处理使用教程合集

本专题整合了Java字符串截取、处理、使用、实战等等教程内容,阅读专题下面的文章了解详细操作教程。

0

2026.01.29

Java空对象相关教程合集
Java空对象相关教程合集

本专题整合了Java空对象相关教程,阅读专题下面的文章了解更多详细内容。

3

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号