全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Polars GroupBy:高效忽略 NaN 计算分组均值的正确方法

在 polars 中,`mean()` 默认不自动忽略 nan;推荐使用 `drop_nans()` 预过滤或 `fill_nan(none)` 转换空值,二者均能正确计算分组均值,且性能优异、完全向量化。

当使用 Polars 进行分组聚合(如 group_by(...).agg(...))并计算数值列均值时,一个常见误区是认为 pl.col("values").mean() 会像 pandas 一样自动跳过 NaN —— 实际上,Polars v0.19.19+ 的 mean() 对含 NaN 的 Series 默认返回 NaN,导致整组结果失效(如示例中 group "A" 得到 NaN 而非 1.0)。

✅ 正确且高效的解决方案是在调用 mean() 前主动处理 NaN,而非依赖 .map_elements() 等非向量化方式(其性能差、无法利用 Polars 引擎优化)。以下是两种推荐做法:

✅ 方法一:drop_nans() —— 直观清晰,语义明确

import polars as pl
import numpy as np

test_data = pl.DataFrame({
    "group": ["A", "A", "B", "B"],
    "values": [1.0, np.nan, 2.0, 3.0]
})

result = test_data.group_by("group").agg(
    pl.col("values").drop_nans().mean().alias("mean_ignore_nan")
)
print(result)

输出:

shape: (2, 2)
┌───────┬────────────────┐
│ group ┆ mean_ignore_nan │
│ ---   ┆ ---             │
│ str   ┆ f64             │
╞═══════╪═════════════════╡
│ A     ┆ 1.0             │
│ B     ┆ 2.5             │
└───────┴─────────────────┘

drop_nans() 会物理移除所有 NaN 值(保留 null 不变),后续 mean() 在纯数值序列上运行,结果准确且高效。

✅ 方法二:fill_nan(None) —— 性能更优(尤其大数据量)

result = test_data.group_by("group").agg(
    pl.col("values").fill_nan(None).mean().alias("mean_ignore_nan")
)

该方法将 NaN 转换为 null,而 Polars 的聚合函数(包括 mean())原生忽略 null —— 这与 drop_nans() 逻辑等价,但底层更轻量,避免了数据重排。

? 性能对比(1 亿行,20% NaN)

  • drop_nans().mean():≈ 1.21 秒
  • fill_nan(None).mean():≈ 0.74 秒(快约 1.6×)

⚠️ 注意:性能优势随分组数增加可能减弱(因 fill_nan 在多组场景下并行度略低),但对绝大多数业务规模(百万级以下),差异可忽略;优先选择语义更直观的 drop_nans(),仅在极端性能敏感场景选用 fill_nan(None)。

❌ 避免方案:map_elements + np.nanmean

# ❌ 不推荐:失去向量化优势,速度慢、不可扩展
pl.col("values").map_elements(lambda x: np.nanmean(x.to_numpy()))

该写法强制转为 NumPy 数组并逐组 Python 调用,完全绕过 Polars 查询引擎优化,应严格避免。

✅ 总结建议

场景 推荐方法 理由
一般用途、代码可读性优先 drop_nans().mean() 语义直白,行为确定,维护友好
百万级以上数据、极致性能要求 fill_nan(None).mean() 底层更高效,实测提速显著
需同时处理 NaN 和 null 统一先 fill_nan(None) 再聚合 确保两者均被忽略

无论哪种方式,都确保了与 pandas .groupby(...).mean() 一致的行为——安全、正确、高性能


# python  # 大数据  # 聚合函数  # 代码可读性 


相关文章: logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  购物网站制作公司有哪些,哪个购物网站比较好?  淘宝制作网站有哪些,淘宝网官网主页?  网站制作员失业,怎样查看自己网站的注册者?  建站之星如何实现五合一智能建站与营销推广?  如何用花生壳三步快速搭建专属网站?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  宁波自助建站系统如何快速打造专业企业网站?  网站制作网站,深圳做网站哪家比较好?  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?  如何在建站主机中优化服务器配置?  建站之星北京办公室:智能建站系统与小程序生成方案解析  代刷网站制作软件,别人代刷火车票靠谱吗?  建站VPS配置与SEO优化指南:关键词排名提升策略  制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  如何基于云服务器快速搭建个人网站?  ,怎么在广州志愿者网站注册?  如何快速生成橙子建站落地页链接?  建站之星好吗?新手能否轻松上手建站?  制作门户网站的参考文献在哪,小说网站怎么建立?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  网站好制作吗知乎,网站开发好学吗?有什么技巧?  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  建站VPS能否同时实现高效与安全翻墙?  建站之星CMS五站合一模板配置与SEO优化指南  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  建站之星图片链接生成指南:自助建站与智能设计教程  如何快速搭建FTP站点实现文件共享?  如何在服务器上三步完成建站并提升流量?  如何用PHP快速搭建CMS系统?  如何挑选高效建站主机与优质域名?  ,柠檬视频怎样兑换vip?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  建站之星导航配置指南:自助建站与SEO优化全解析  Python多线程使用规范_线程安全解析【教程】  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  如何在企业微信快速生成手机电脑官网?  制作网站的模板软件,网站怎么建设?  宝华建站服务条款解析:五站合一功能与SEO优化设置指南  如何获取PHP WAP自助建站系统源码?  定制建站方案优化指南:企业官网开发与建站费用解析  简单实现Android验证码  建站主机服务器选型指南与性能优化方案解析  如何破解联通资金短缺导致的基站建设难题?  如何在Golang中引入测试模块_Golang测试包导入与使用实践  如何快速启动建站代理加盟业务?  详解免费开源的DotNet二维码操作组件ThoughtWorks.QRCode(.NET组件介绍之四) 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。