繁体   English   中英

如何在行级别比较两个海量火花数据帧并打印差异

[英]How to compare two massive spark dataframes on row level and print the difference

我有两个非常大的火花数据框。 我想在行级别比较它并只打印差异

例如:

df1= firstname:abc lastname:xyz company:123


df2= firstname:abc lastname:xyz company:456


预期产出- diff= company(df1):123 company(df2):456

就我而言,您所描述的问题没有最佳解决方案。 因为,只有当您拥有可以连接两个数据框的column/reference时,才能找到数据框之间的差异。

有了这个注意,一种方法是使用subtract函数找到在某种程度上有所帮助的差异。

>>> df_1.show()
+-----+-----+-----+
|fname|lname|cmpny|
+-----+-----+-----+
|  abc|  xyz|  123|
+-----+-----+-----+

>>> df_2.show()
+-----+-----+-----+
|fname|lname|cmpny|
+-----+-----+-----+
|  abc|  xyz|  456|
+-----+-----+-----+

>>> df_1.select('*').subtract(df_2.select('*')).show()
+-----+-----+-----+
|fname|lname|cmpny|
+-----+-----+-----+
|  abc|  xyz|  123|
+-----+-----+-----+

>>> df_2.select('*').subtract(df_1.select('*')).show()
+-----+-----+-----+
|fname|lname|cmpny|
+-----+-----+-----+
|  abc|  xyz|  456|
+-----+-----+-----+

我想你正在寻找除了

df1.except(df2)

将返回 df1 中而不是 df2 中的行。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM