通过检查值是否在列表中以及其他条件来过滤Spark DataFrame

Bam*_*mqf 22 scala apache-spark apache-spark-sql

作为简化示例,我尝试使用以下代码过滤Spark DataFrame:

val xdf = sqlContext.createDataFrame(Seq(
  ("A", 1), ("B", 2), ("C", 3)
)).toDF("name", "cnt")
xdf.filter($"cnt" >1 || $"name" isin ("A","B")).show()
Run Code Online (Sandbox Code Playgroud)

然后它错误:

org.apache.spark.sql.AnalysisException: cannot resolve '((cnt > 1) || name)' due to data type mismatch: differing types in '((cnt > 1) || name)' (boolean and string).;
Run Code Online (Sandbox Code Playgroud)

什么是正确的方法呢?在我看来,它在name列之后停止阅读.它是解析器中的错误吗?我正在使用Spark 1.5.1

小智 39

希望这会对你有所帮助:

val list = List("x","y","t") 
xdf.filter($"column".isin(list:_*))
Run Code Online (Sandbox Code Playgroud)

  • @WalrustheCat它将列表转换为可变数量的参数. (6认同)
  • `:_*`做什么? (5认同)
  • 那是什么意思? (5认同)
  • 我相信`_:*`被称为"splat"(https://alvinalexander.com/bookmarks/scala/scalas-missing-splat-operator) (4认同)

zer*_*323 29

你必须用括号表示个别表达式:

xdf.filter(($"cnt" > 1) || ($"name" isin ("A","B"))).show()
Run Code Online (Sandbox Code Playgroud)