删除Spark DataFrame的第一行

时间:2016-07-12 19:45:31

标签: scala apache-spark dataframe

我的Spark / Scala代码中有一个DataFrame类型的变量rawData

我想删除第一个元素,如下所示:

rawData.drop(1)

但是,drop功能不可用。

删除第一个元素的最简单方法是什么?

1 个答案:

答案 0 :(得分:5)

要回答这个问题,我们首先必须澄清什么是DataFrame的第一个元素,因为我们不是在谈论放置在单个机器上的有序集合,而是在处理分布式集合而没有特定的顺序分区,所以答案并不明显。

如果您想从可以使用的每个分区中删除第一个元素:

df.mapPartitions(iterator => iterator.drop(1))

如果要从第一个分区中删除第一个元素,可以使用:

val rdd = df.rdd.mapPartitionsWithIndex{
  case (index, iterator) => if(index==0) iterator.drop(1) else iterator
}
sqlContext.createDataFrame(rdd, df.schema)

这两种解决方案都不是很优雅,而且看起来很糟糕,知道完整的用例会很有趣,也许有更好的方法。