DataFrame,计算唯一值,Java

DataFrame, count unique values, Java

我有一个 DataFrame,我想计算此数据框中两列的唯一行数。例如:

a x
a x
a y
b y 
b y
b y

应该是:

a x 2
a y 1
b y 3

我在pandasDataFrame中知道这个操作的解决方案,但现在我想直接在Java中进行(最好的方法是Java8)。

我不确定你有什么输入类型,但假设你有一个 List<DataFrame> listDataFrame 实现 equals/hashcode 正如预期的那样,你可以使用两个收集器的组合:

Map<DataFrame, Long> count = list.stream().collect(groupingBy(x -> x, counting()));

需要以下静态导入:

import static java.util.stream.Collectors.counting;
import static java.util.stream.Collectors.groupingBy;

我自己找到了下一个解决方案。复制到这里,如果有人有兴趣....

DataFrame df2 = df.groupBy("Column_one", "Column_two").count();
df2.show();