首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >火花数据计算柱

火花数据计算柱
EN

Stack Overflow用户
提问于 2016-06-18 16:41:04
回答 1查看 8.7K关注 0票数 2

我正在学习星星之火(scala),并且我正在创建一个带有派生列的dataframe。我正在努力找出最佳做法。

我的用例有两个派生列,它们寻找另一个列的值-例如-

代码语言:javascript
复制
if (col22 = "USD") then col1 = "US" elseif (col22 = "CDN" the col1 = "CA" else null)

另一个用例是

代码语言:javascript
复制
if(col23 = "us" && col100 = "abc") then col2 = "10" else if (col23 = "us" && col100 = "bacd" && col99 is null then col2 = 11 else null)

问题-我已经为上述计算编写了UDF函数。我想知道有什么更好的方法吗?编写udf函数是最佳实践。我将只在我的代码中使用这些函数一次。

我的Scala密码-

代码语言:javascript
复制
def udf1 = udf((col22: String){  (col22) match {
    case col22 if (col22 == "USD") => "US"
    case col22 if (col22 == "CDN") => "CA"
    case _ => null  } })

val df1= df.select($"col1", $"col2", udf1($"col22").as("newcol"), udf2($"col23", $"col100").as(newcol2))
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-18 18:36:49

你可以这样做:

代码语言:javascript
复制
val df1 = df.withColumn(
  "newcol",
  when($"col22" === "USD", lit("US")).otherwise(
    when($"col22" === "CDN", lit("CA")).otherwise(lit(null))
  )
)
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37899320

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档