gpt4 book ai didi

java - 流收集操作可以是特定的 POJO 而不是 Map 吗?

转载 作者:行者123 更新时间:2023-11-30 05:39:03 25 4
gpt4 key购买 nike

我想对多个字段进行分组并生成 POJO 输出。

原始的 POJO 是这样的:

@Data
@AllArgsConstructor
@NoArgsConstructor
@EqualsAndHashCode(onlyExplicitlyIncluded = true)
public class DealDTO {
@EqualsAndHashCode.Include
private String id;

private Float amount;
private Date closeDate;
private String stage;

public int getYear() {
return getLocalDate().getYear();
}

public int getMonth() {
return getLocalDate().getMonthValue();
}

private LocalDate getLocalDate() {
return getCloseDate().toInstant()
.atZone(ZoneId.systemDefault()).toLocalDate();
}
}

目标 POJO

@Data
public class GroupByYearMonthStageDTO {
private int year;
private int month;
private String stage;
private DoubleSummaryStatistics statistics;
}

下面的代码产生预期的分组:

List<DealDTO> list;
var grouping = list.stream().collect(
groupingBy(DealDTO::getYear,
groupingBy(DealDTO::getMonth,
groupingBy(DealDTO::getStage, summarizingDouble(DealDTO::getAmount)))));

但是......分组的类型是:

Map<Integer, Map<Integer, Map<String, DoubleSummaryStatistics>>> 

我想看看收集操作中是否有办法将输出更改为最终分组类型:

List<GroupByYearMonthStageDTO>

最佳答案

作为 groupingBy 的第一个参数,发送创建目标 POJO 的 lambda,并使用 summarizingDouble 收集器作为第二个参数。之后,您必须遍历结果 map 并设置统计信息

Map<GroupByYearMonthStageDTO, DoubleSummaryStatistics> collect = list.stream()
.collect(groupingBy(d -> new GroupByYearMonthStageDTO(d.getYear(), d.getMonth(), d.getStage()),
summarizingDouble(DealDTO::getAmount)));

collect.forEach(GroupByYearMonthStageDTO::setStatistics);
Set<GroupByYearMonthStageDTO> groupByYearMonthStageDTOS = collect.keySet();

关于java - 流收集操作可以是特定的 POJO 而不是 Map 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56045579/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com