Apache Spark,如何将“CASE WHEN ... ELSE ...”计算列添加到现有的DataFrame中?

在不同Spark版本中,创建条件列的方法有所不同。在Spark 1.4.0及更高版本,可以使用`when/otherwise`语法,例如将颜色为'Green'的列设置为1,否则为0。在Spark 1.3.0版本中,需要借助用户定义函数(UDF)来实现相同功能。而在Spark 1.5.0中,可以使用SQL表达式的`case when`来完成这一任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在SPARK 1.4.0版本中。您可以使用WHERE/OUCK语法:
// Create the dataframe
val df = Seq(“Red”, “Green”, “Blue”).map(Tuple1.apply).toDF(“color”)

// Use when/otherwise syntax
val df1 = df.withColumn(“Green_Ind”, when($“color” === “Green”, 1).otherwise(0))

如果您使用的是SMARK 1.3.0,则可以选择使用UDF:
// Define the UDF
val isGreen = udf((color: String) => {
if (color == “Green”) 1
else 0
})
val df2 = df.withColumn(“Green_Ind”, isGreen($“color”))

在Spark1.5.0中:您还可以使用SQL语法Exr函数
val df3 = df.withColumn(“Green_Ind”, expr(“case when color = ‘green’ then 1 else 0 end”))

或者
df.registerTempTable(“data”)
val df4 = sql(""" select *, case when color = ‘green’ then 1 else 0 end as Green_ind from data “”")

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值