我有一个数据框架,我想计算这个数据框架中两列的唯一行。例如:
a x
a x
a y
b y
b y
b y
应该是:
a x 2
a y 1
b y 3
我知道在pandas DataFrame中此操作的解决方案,但现在我想直接在Java中执行(最好的方法是Java 8)。
我不确定您有什么输入类型,但假设您有List<DataFrame> list
和DataFrame
实现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();