0

0

使用 PySpark 顺序填充 DataFrame 中的缺失值

霞舞

霞舞

发布时间:2025-09-06 11:41:02

|

411人浏览过

|

来源于php中文网

原创

使用 pyspark 顺序填充 dataframe 中的缺失值

本文介绍了如何使用 PySpark 顺序填充 DataFrame 中的缺失值。通过使用窗口函数和 last 函数,我们可以高效地将每个 group_id 中的空值填充为该组的第一个非空值,从而解决在大型 DataFrame 中处理缺失值的问题。该方法适用于已知 row_id 是顺序且唯一的情况。

在数据处理过程中,经常会遇到需要填充 DataFrame 中缺失值的情况。当缺失值具有一定的顺序性或分组性时,例如,希望将每个分组中的缺失值填充为该分组的第一个有效值,可以使用 PySpark 的窗口函数来实现。以下将详细介绍如何使用 PySpark 顺序填充 DataFrame 中的缺失值。

准备工作

首先,需要创建一个 SparkSession 并准备好示例数据。

from pyspark.sql import SparkSession
from pyspark.sql import functions as F
from pyspark.sql.window import Window

# 创建 SparkSession
spark = SparkSession.builder.appName("FillMissingValues").getOrCreate()

# 示例数据
data = [(1, 1), (2, None), (3, None), (4, None), (5, 5), (6, None), (7, None), (8, 8), (9, None), (10, None), (11, None), (12, None)]
columns = ["row_id", "group_id"]
df = spark.createDataFrame(data, columns)

df.show()

这段代码首先导入必要的库,包括 SparkSession 用于创建 Spark 会话,functions (别名 F) 用于使用 Spark 内置函数,以及 Window 用于定义窗口规范。然后,创建一个名为 "FillMissingValues" 的 SparkSession。接着,创建包含 row_id 和 group_id 的示例数据,并将其转换为 PySpark DataFrame。最后,使用 df.show() 显示 DataFrame 的内容。

InsCode
InsCode

InsCode 是CSDN旗下的一个无需安装的编程、协作和分享社区

下载

使用窗口函数填充缺失值

核心思路是使用窗口函数 last 来查找每个 row_id 之前(包括当前行)的最后一个非空 group_id 值。通过定义一个基于 row_id 排序的窗口,并设置其范围为从第一行到当前行,就可以实现顺序填充的效果。

# 定义窗口规范
windowSpec = Window.orderBy("row_id").rowsBetween(Window.unboundedPreceding, 0)

# 使用 last 函数填充缺失值
filled_df = df.withColumn("group_id", F.last("group_id", ignorenulls=True).over(windowSpec))

# 显示结果
filled_df.show()

这段代码首先定义了一个窗口规范 windowSpec,该规范基于 row_id 进行排序,并指定窗口的范围为从第一行 (Window.unboundedPreceding) 到当前行 (0)。然后,使用 withColumn 函数创建一个新的 group_id 列,其值为 F.last("group_id", ignorenulls=True).over(windowSpec)。F.last 函数查找窗口中最后一个非空 (ignorenulls=True) 的 group_id 值,并将其应用于每个 row_id。最后,使用 filled_df.show() 显示填充后的 DataFrame。

代码解释

  • Window.orderBy("row_id"): 定义窗口的排序方式,这里按照 row_id 升序排列。确保了顺序填充的正确性。
  • Window.rowsBetween(Window.unboundedPreceding, 0): 定义窗口的范围。Window.unboundedPreceding 表示窗口从第一行开始,0 表示窗口到当前行结束。这意味着对于每一行,窗口都包含从第一行到当前行的所有行。
  • F.last("group_id", ignorenulls=True).over(windowSpec): F.last 函数用于获取窗口中最后一个非空值。ignorenulls=True 参数表示忽略空值,只查找非空值。over(windowSpec) 将 last 函数应用到定义的窗口上。

注意事项

  • 确保 row_id 是顺序且唯一的。如果 row_id 不是顺序的,则需要先对其进行排序。
  • 如果数据量非常大,可以考虑对 DataFrame 进行分区,以提高计算效率。
  • 此方法适用于将缺失值填充为该组的第一个有效值。如果需要使用其他填充策略,例如使用平均值或中位数,则需要使用不同的函数。

总结

通过使用 PySpark 的窗口函数和 last 函数,可以方便地实现 DataFrame 中缺失值的顺序填充。这种方法在处理具有分组性和顺序性的数据时非常有效,可以帮助我们更好地进行数据清洗和分析。

相关专题

更多
常用的数据库软件
常用的数据库软件

常用的数据库软件有MySQL、Oracle、SQL Server、PostgreSQL、MongoDB、Redis、Cassandra、Hadoop、Spark和Amazon DynamoDB。更多关于数据库软件的内容详情请看本专题下面的文章。php中文网欢迎大家前来学习。

973

2023.11.02

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

19

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

61

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

87

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

39

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

19

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

160

2026.01.18

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Excel 教程
Excel 教程

共162课时 | 12.5万人学习

PHP基础入门课程
PHP基础入门课程

共33课时 | 2万人学习

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

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