我正在尝试根据另一个dataframe列中的值去复制Spark dataframe列中的值。看来withColumn()只在单个数据中工作,子查询要到第2版才能完全可用,我想我可以尝试加入这些表,但这似乎有点麻烦。以下是一般的想法:
df.take(1)
[Row(TIMESTAMP='20160531 23:03:33', CLIENT ID=233347, ROI NAME='my_roi', ROI VALUE=1, UNIQUE_ID='173888')]
df_re.take(1)
[Row(UNIQUE_ID='6866144:ST64PSIMT5MB:1')]基本上,只想从df中获取值,并删除在df_re中找到的任何值,然后返回包含已删除重复项的行的整个数据帧。我相信我可以迭代每一个,但我想知道是否有更好的方法。有什么想法吗?
发布于 2016-06-06 18:10:49
这样做的方法是执行一个left_outer join,然后筛选连接的右侧为空的位置。类似于:
val df1 = Seq((1,2),(2,123),(3,101)).toDF("uniq_id", "payload")
val df2 = Seq((2,432)).toDF("uniq_id", "other_data")
df1.as("df1").join(
df2.as("df2"),
col("df1.uniq_id") === col("df2.uniq_id"),
"left_outer"
).filter($"df2.uniq_id".isNull)https://stackoverflow.com/questions/37663828
复制相似问题