京公网安备 11010802034615号
经营许可证编号:京B2-20210330
Pandas是一种开源Python库,用于数据操作和数据分析。其中的groupby函数可以将数据按指定的列或条件进行分组,这是数据分析中非常常用的功能之一。在pandas分组后,我们可能需要对每个分组进行遍历处理,例如进行统计、计算、筛选等操作。本文将介绍如何在pandas分组后对数据进行遍历处理。
在pandas中,可以使用groupby方法对数据进行分组,该函数返回一个GroupBy对象。GroupBy对象是一个非常强大的对象,它包含了很多有用的方法,可以用来对数据进行聚合、转换、过滤等操作。下面是一个示例,展示如何通过groupby方法分组数据:
import pandas as pd # 创建一个DataFrame data = {'name': ['小明', '小红', '小明', '小红'], 'age': [18, 20, 19, 21], 'city': ['北京', '上海', '广州', '深圳']}
df = pd.DataFrame(data) # 按照name列进行分组 grouped = df.groupby('name')
对于groupby方法分组后的数据,我们可以使用for循环来遍历每个分组。在每次循环中,我们将得到一个元组,其中第一个元素是分组的名称(也就是按照哪个列进行分组),第二个元素是一个DataFrame对象,包含了该分组的所有数据。下面是一个示例:
# 遍历每个分组 for name, group in grouped: print(name) print(group)
输出结果如下:
小明 name age city 0 小明 18 北京 2 小明 19 广州 小红 name age city 1 小红 20 上海 3 小红 21 深圳
在遍历分组后,我们可以对每个分组进行统计计算。例如,我们可以计算每个分组的平均值、最大值、最小值等。在pandas中,我们可以使用agg函数来实现这些操作。agg函数接受一个字典参数,其中键表示要计算的列名称,值表示要进行的计算操作。下面是一个示例:
# 计算每个分组的平均年龄和最大年龄 result = grouped.agg({'age': ['mean', 'max']}) print(result)
输出结果如下:
age
mean max
name
小明 18.500 19
小红 20.500 21
在遍历分组后,我们还可以根据条件筛选分组。例如,我们可以只选择年龄大于等于20岁的分组。在pandas中,我们可以使用filter函数来实现这个操作。filter函数接受一个函数参数,该函数应该返回一个布尔值,表示是否选择该分组。下面是一个示例:
# 筛选年龄大于等于20岁的分组 def filter_func(x): return x['age'].mean() >= 20 result = grouped.filter(filter_func) print(result)
输出结果如下:
name age city 1 小红 20 上海 3 小红 21 深圳
在遍历分组后,我们还可以对每个分组进行转换。例如,我们可以将每个分组的年龄减去该分组的平均年龄。在pandas中,我们可以使用transform函数来实现这个操作。transform函数接受一个函数参数,该函数
应该返回一个与分组大小相同的Series或DataFrame对象。下面是一个示例:
# 将每个分组的年龄减去平均年龄 def transform_func(x):
x['age'] = x['age'] - x['age'].mean() return x
result = grouped.apply(transform_func) print(result)
输出结果如下:
name age city 0 小明 -0.500 北京 1 小红 0.500 上海 2 小明 0.500 广州 3 小红 0.500 深圳
在本文中,我们介绍了如何在pandas分组后对数据进行遍历处理。首先,我们使用groupby方法对数据进行分组。然后,我们可以使用for循环遍历分组,并对每个分组进行统计、筛选、转换等操作。例如,我们可以使用agg函数计算每个分组的平均值、最大值等;使用filter函数根据条件选择分组;使用transform函数对每个分组进行转换。这些操作非常有用,在实际的数据分析和处理中经常会用到。
想快速入门Python数据分析?这门课程适合你!
如果你对Python数据分析感兴趣,但不知从何入手,推荐你学习《山有木兮:Python数据分析极简入门》。这门课程专为初学者设计,内容简洁易懂,手把手教你掌握Python数据分析的核心技能,助你轻松迈出数据分析的第一步。

学习入口:https://edu.cda.cn/goods/show/3429?targetId=5724&preview=0
开启你的Python数据分析之旅,从入门到精通,只需一步!
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在MySQL数据库优化中,分区表是处理海量数据的核心手段——通过将大表按分区键(如时间、地域、ID范围)分割为多个独立的小分区 ...
2026-03-19在商业智能与数据可视化领域,同比、环比增长率是分析数据变化趋势的核心指标——同比(YoY)聚焦“长期趋势”,通过当前周期与 ...
2026-03-19在数据分析与建模领域,流传着一句行业共识:“数据决定上限,特征决定下限”。对CDA(Certified Data Analyst)数据分析师而言 ...
2026-03-19机器学习算法工程的核心价值,在于将理论算法转化为可落地、可复用、高可靠的工程化解决方案,解决实际业务中的痛点问题。不同于 ...
2026-03-18在动态系统状态估计与目标跟踪领域,高精度、高鲁棒性的状态感知是机器人导航、自动驾驶、工业控制、目标检测等场景的核心需求。 ...
2026-03-18“垃圾数据进,垃圾结果出”,这是数据分析领域的黄金法则,更是CDA(Certified Data Analyst)数据分析师日常工作中时刻恪守的 ...
2026-03-18在机器学习建模中,决策树模型因其结构直观、易于理解、无需复杂数据预处理等优势,成为分类与回归任务的首选工具之一。而变量重 ...
2026-03-17在数据分析中,卡方检验是一类基于卡方分布的假设检验方法,核心用于分析分类变量之间的关联关系或实际观测分布与理论期望分布的 ...
2026-03-17在数字化转型的浪潮中,企业积累的数据日益庞大且分散——用户数据散落在注册系统、APP日志、客服记录中,订单数据分散在交易平 ...
2026-03-17在数字化时代,数据分析已成为企业决策、业务优化、增长突破的核心支撑,从数据仓库搭建(如维度表与事实表的设计)、数据采集清 ...
2026-03-16在数据仓库建设、数据分析(尤其是用户行为分析、业务指标分析)的实践中,维度表与事实表是两大核心组件,二者相互依存、缺一不 ...
2026-03-16数据是CDA(Certified Data Analyst)数据分析师开展一切工作的核心载体,而数据读取作为数据生命周期的关键环节,是连接原始数 ...
2026-03-16在用户行为分析实践中,很多从业者会陷入一个核心误区:过度关注“当前数据的分析结果”,却忽视了结果的“泛化能力”——即分析 ...
2026-03-13在数字经济时代,用户的每一次点击、浏览、停留、转化,都在传递着真实的需求信号。用户行为分析,本质上是通过收集、整理、挖掘 ...
2026-03-13在金融、零售、互联网等数据密集型行业,量化策略已成为企业挖掘商业价值、提升决策效率、控制经营风险的核心工具。而CDA(Certi ...
2026-03-13在机器学习建模体系中,随机森林作为集成学习的经典算法,凭借高精度、抗过拟合、适配多场景、可解释性强的核心优势,成为分类、 ...
2026-03-12在机器学习建模过程中,“哪些特征对预测结果影响最大?”“如何筛选核心特征、剔除冗余信息?”是从业者最常面临的核心问题。随 ...
2026-03-12在数字化转型深度渗透的今天,企业管理已从“经验驱动”全面转向“数据驱动”,数据思维成为企业高质量发展的核心竞争力,而CDA ...
2026-03-12在数字经济飞速发展的今天,数据分析已从“辅助工具”升级为“核心竞争力”,渗透到商业、科技、民生、金融等各个领域。无论是全 ...
2026-03-11上市公司财务报表是反映企业经营状况、盈利能力、偿债能力的核心数据载体,是投资者决策、研究者分析、从业者复盘的重要依据。16 ...
2026-03-11