
本文旨在解决在 Pandas 中使用 groupby() 和 rolling().mean() 进行分组滚动平均计算时遇到的 TypeError: incompatible index 错误和结果错位问题。通过深入分析 groupby().rolling() 操作产生的多级索引,并引入 droplevel() 方法来调整索引,确保计算结果能正确地与原始 DataFrame 对齐,从而实现精确的分组滚动统计。
在数据分析中,我们经常需要在不同的数据组内计算滚动(或移动)平均值、总和等统计量。例如,在一个包含多个类别的数据集中,我们可能需要分别计算每个类别的销售额的3天滚动平均值。Pandas 提供了强大的 groupby() 和 rolling() 方法来支持这类操作,但其组合使用时,如果不注意索引的处理,可能会遇到一些常见的陷阱。
考虑以下示例 DataFrame,我们希望根据 'a' 和 'b' 列进行分组,然后计算 'c' 列的3个元素的滚动平均值。
import pandas as pd
import numpy as np
df = pd.DataFrame({
'a': np.random.choice(['x', 'y'], 8),
'b': np.random.choice(['r', 's'], 8),
'c': np.arange(1, 8 + 1)
})
print("原始 DataFrame:")
print(df)一个直观但错误的尝试是直接将 groupby().rolling().mean() 的结果赋值给 DataFrame 的新列:
# 错误的尝试 # df['ROLLING_MEAN'] = df.groupby(['a', 'b'])['c'].rolling(3).mean()
执行上述代码会抛出 TypeError: incompatible index of inserted column with frame index 错误。这个错误明确指出,尝试插入的 Series 的索引与 DataFrame 的索引不兼容。
为了规避这个错误,有人可能会尝试在链式调用中添加 .values:
# 另一个错误的尝试:使用 .values
df['ROLLING_MEAN_WRONG'] = df.groupby(['a', 'b'])['c'].rolling(3).mean().values
print("\n使用 .values 后的 DataFrame (结果错误):")
print(df)
# 检查特定分组的结果
print("\n特定分组 (a='x', b='r') 的结果 (仍然错误):")
print(df[
(df['a'] == 'x') &
(df['b'] == 'r')
])虽然 .values 避免了 TypeError,但它会产生错误的结果。例如,对于 (a='x', b='r') 这个分组,可能会看到如下输出(具体数值可能因随机数据而异):
a b c ROLLING_MEAN_WRONG 0 x r 1 NaN 2 x r 3 2.666667 3 x r 4 4.000000 4 x r 5 5.666667 7 x r 8 NaN
这里的问题在于,滚动平均值 5.666 出现在 'c' 列值仅为 1, 3, 4, 5, 8 的分组中,这显然是不正确的。5.666 意味着 (X + Y + Z) / 3,而在这个分组中,还没有出现足够大的数值来产生这样的滚动平均。这种错误是由于 .values 方法在将 Series 转换为 NumPy 数组时,丢失了原有的索引信息,导致数据在赋值时进行了错误的按位置对齐。
为了理解为什么会发生这种情况,我们首先来看一下 df.groupby(['a', 'b'])['c'].rolling(3).mean() 的原始输出:
万彩商图
专为电商打造的AI商拍工具,快速生成多样化的高质量商品图和模特图,助力商家节省成本,解决素材生产难、产图速度慢、场地设备拍摄等问题。
212
查看详情
# 查看分组滚动平均的原始输出
grouped_rolling_output = df.groupby(['a', 'b'])['c'].rolling(3).mean()
print("\n分组滚动平均的原始输出 (多级索引):")
print(grouped_rolling_output)输出示例:
a b
x r 3 NaN
4 NaN
6 5.333333
s 1 NaN
y r 2 NaN
5 NaN
s 0 NaN
7 NaN
Name: c, dtype: float64可以看到,这个 Series 拥有一个多级索引(MultiIndex),其中包含了分组键 'a' 和 'b',以及原始 DataFrame 的索引。当尝试将其直接赋值给 df['ROLLING_MEAN'] 时,Pandas 发现这个多级索引与 df 的单一整数索引不兼容,因此抛出 TypeError。
而 .values 方法则粗暴地将这个多级索引的 Series 转换为一个纯粹的 NumPy 数组,丢弃了所有索引信息。当这个数组被赋值回 DataFrame 时,Pandas 只能进行按位置(positional)对齐。由于 rolling() 操作会在每个分组的开头产生 NaN 值,这些 NaN 值在 .values 转换后会被放置在数组的开头,从而导致与原始 DataFrame 的行错位,使得滚动平均值被错误地分配到不属于它的行。
解决这个问题的关键在于,在将分组滚动计算的结果赋值回原始 DataFrame 之前,将其索引调整为与原始 DataFrame 的索引一致。pandas.Series.droplevel() 方法正是为此而生,它可以移除 Series 或 DataFrame 索引中的一个或多个级别。
我们需要移除由 groupby() 操作引入的 'a' 和 'b' 这两个索引级别,只保留原始 DataFrame 的行索引。
# 正确的解决方案
df['ROLLING_MEAN_CORRECT'] = df.groupby(['a', 'b'])['c'] \
.rolling(3).mean() \
.droplevel(['a', 'b'])
print("\n使用 droplevel() 后的 DataFrame (结果正确):")
print(df)
# 检查特定分组的正确结果
print("\n特定分组 (a='x', b='r') 的正确结果:")
print(df[
(df['a'] == 'x') &
(df['b'] == 'r')
])代码解析:
预期输出示例: (请注意,由于数据是随机生成的,以下输出仅为示例,实际运行时请根据您的随机数据进行验证)
a b c ROLLING_MEAN_CORRECT 0 y s 1 NaN 1 y r 2 NaN 2 y s 3 NaN 3 y r 4 NaN 4 y s 5 3.000000 # (1+2+5)/3 或 (3+4+5)/3 等,取决于具体分组数据 5 x r 6 NaN 6 y r 7 4.333333 # (2+5+7)/3 或 (4+5+7)/3 等 7 x r 8 NaN
现在,如果检查特定分组 (a='x', b='r') 的结果,会发现滚动平均值被正确地计算并对齐到相应的行。例如,如果 (a='x', b='r') 组的数据是 c=[1, 3, 4, 5, 8],那么:
通过理解 groupby().rolling() 操作如何产生多级索引,并掌握使用 droplevel() 进行索引调整的技巧,您可以有效地在 Pandas 中执行复杂的分组滚动统计,确保数据的准确性和代码的健壮性。
以上就是Pandas 分组滚动计算:解决索引不兼容与结果错位问题的详细内容,更多请关注其它相关文章!
# 将其
# 网站建设和管理sass系统
# 北碚的网站推广公司
# 公司网站建设哪个最好做
# 泰州网站建设路拍照
# 酒泉关键词排名价格
# tumblr seo ha joon
# 曲靖哪里有网站优化
# 河南网站优化报价多少钱
# 天水查看关键词排名
# seo获客系统怎么注册
# 这两个
# app
# 出现在
# 正确地
# 转换为
# 移除
# 多个
# 链式
# 不兼容
# 自定义
# 为什么
# 性能瓶颈
# 工具
相关栏目:
【
Google疑问12 】
【
Facebook疑问10 】
【
优化推广96088 】
【
技术知识133117 】
【
IDC资讯59369 】
【
网络运营7196 】
【
IT资讯61894 】
相关推荐:
包子漫画官网链接官方地址 包子漫画在线观看官网首页入口
Yandex无需登录畅游 俄罗斯搜索引擎最新官网指南
漫蛙漫画直连入口 _ manwa官方备用入口实时检测
偃武诸葛亮阵容搭配推荐
快手网页版官方访问 快手网页版页面在线打开
J*aScript 数值去小数位处理:多种方法与实践
mail.qq.com登录入口 QQ邮箱网页版直达
PHP实现等比数列:构建数组元素基于前一个值递增的方法
4399造梦西游3无敌版_4399游戏入口
如何修改Windows截图的默认保存位置_告别C盘让桌面更整洁【教程】
word表格如何按某一列内容进行排序_Word表格按列排序方法
百度地图离线地图无法加载如何解决 百度地图离线地图加载优化方法
sublime text 4如何安装_最新版sublime下载与汉化教程
猫眼app抢票快还是小程序快
谷歌邮箱怎么换绑定邮箱Gmail安全备份邮箱修改方法
TikTok网页版实时观看入口 TikTok网页版短视频在线浏览
Win10如何关闭开机锁屏界面_Windows10跳过锁屏直接登录设置
智学网成绩单查询系统网_智学网学生平台登录
c++20的指定初始化(Designated Initializers)怎么用_c++ C风格结构体初始化
《东方财富》条件单关闭方法
Animex动漫社社登录官网 Animex动漫社资源社入口直达
WooCommerce购物车:强制显示所有交叉销售商品教程
稻壳阅读器官方直达网址链接 稻壳阅读器文档阅读平台主页资源入口
荣耀magicv5怎么上手测评
动漫岛在线动漫网 动漫岛动漫在线观看官方入口
《搜书吧》阅读书籍方法
抖音火山版如何进行提现
CSS动画如何实现图标旋转并放大_transform rotate scale @keyframes实现
Golang如何测试结构体方法_Golang reflect方法测试与调用技巧
GBA模拟器手柄按键设置
VB表达式书写规则解析
4399正版网页版入口高清直达链接
基于键值条件高效映射 Pandas DataFrame 多列数据
之了课堂app做题入口
php如何实现多域名共享session_php存储session到redis与跨域读取配置
Mac hosts文件在哪里_Mac修改hosts文件详细教程
抖音如何解除|直播|权限绑定_抖音关闭并解绑|直播|功能的方法
Win11怎么开启HDR_Windows 11显示器画质增强设置
《饿了么》拼好饭点外卖教程2025
苹果自助维修计划支持哪些设备机型
研招网官方网站正版登录网址_中国研究生招生信息网官网首页
火狐浏览器无法自动更新怎么办 手动更新火狐浏览器到最新版本【解决】
LINUX怎么查看显卡信息_LINUX查看GPU状态
小米手机屏幕失灵乱跳怎么办 屏幕触控问题自检与临时解决方法【应急】
顺丰快递收费标准查询_如何查看顺丰最新收费价格
163邮箱网页版官方登录入口 163邮箱网页版访问页面
如何查询个人病历记录
J*aScript模块加载器_RequireJS原理分析
银信通自动开通原因揭秘
CodeIgniter 3 连接 SQL Server:正确获取查询结果的教程
2025-11-22
运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。