python 平均值代替缺失值_Pyspark数据帧估算——根据指定条件用列平均值替换未知值和缺失值...

本文讲述了如何在Pyspark数据帧中,利用非缺失非未知值计算平均值,并用该平均值替换列中的缺失值和未知值。作者尝试了多种方法,包括when(), where(), replace(), withColumn()和udf等,最终找到了解决方案,同时也探讨了如何遍历数据帧的所有列进行类似操作。" 116621578,10553260,CentOS7配置Samba共享文件夹权限指南,"['Linux', 'Samba', '文件共享', '系统管理', '服务器配置']
摘要由CSDN通过智能技术生成

给定一个Spark数据帧,我想根据该列的非缺失值和非未知值计算一个列的平均值。然后,我想采用这个平均值,并用它替换列缺少的未知值。

例如,假设我使用的是:名为df的数据帧,其中每条记录代表一个单独的记录,所有列都是整数或数字

名为age的列(每条记录的age)

名为missing_age的列(如果该个人没有年龄,则等于1,否则为0)

名为unknown_age的列(如果该个人的年龄未知,则等于1,否则为0)

然后我可以计算这个平均值,如下所示。calc_mean = df.where((col("unknown_age") == 0) & (col("missing_age") == 0))

.agg(avg(col("age")))

或者通过SQL和windows函数mean_compute = hiveContext.sql("select avg(age) over() as mean from df

where missing_age = 0 and unknown_age = 0")

如果可以的话,我不想使用SQL/windows函数。我的挑战是采用这种方法,并使用非SQL方法替换未知/缺少的值。

我试过使用when()、where()、replace()、with column、udf和组合。。。不管我做什么,我要么会犯错,要么结果不是我所期望的。这里有一个例子,我试过的很多事情中有一个没有用。imputed = df.when((col("unknown_age") == 1) | (col("

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值