可以说我下面有一个类有getter和setter但只有默认构造函数。
注意:我不允许更改此类的结构。
class Target {
private String year;
private String month;
private String name;
private double target;
private double achieved;
public String getYear() {
return year;
}
public void setYear(String year) {
this.year = year;
}
public String getMonth() {
return month;
}
public void setMonth(String month) {
this.month = month;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public double getTarget() {
return target;
}
public void setTarget(double target) {
this.target = target;
}
public double getAchieved() {
return achieved;
}
public void setAchieved(double achieved) {
this.achieved = achieved;
}
}
我必须根据年份和名称添加Target和Achieved列值。
Year Month Name Target Achieved
2018 8 Joey 50.00 10.00
2018 9 Joey 200.00 100.00
2018 9 Fred 200.00 150.00
2018 9 Fred 20.00 50.00
所以输出将是:
Year Month Name Target Achieved
2018 8 Joey 50.00 10.00
2018 9 Joey 200.00 100.00
2018 9 Fred 220.00 200.00
我已经看到一个例子,说明如果我有一个接受参数的构造函数我可以实现这样的东西,但我对Group by and sum objects like in SQL with Java lambdas?的概念不太清楚:
我如何使用默认构造函数来获得相同类型的List<Target>
但具有多列的计算值?
看来你需要根据三件事进行分组:Year
,Month
和Name
,所以这看起来像这样:
Collection<Target> merged = yourListOfTargets
.stream()
.collect(Collectors.toMap(
t -> List.of(t.getYear(), t.getMonth(), t.getName()),
Function.identity(),
(left, right) -> {
left.setTarget(left.getTarget() + right.getTarget());
left.setAchieved(left.getAchieved() + right.getAchieved());
return left;
}))
.values();
正如费德里科在评论中提到的那样,这将改变你在最初的List
中的元素。你可能没问题,但如果不是,你需要用一个复制函数替换Function.identity()
,它将从现有函数创建一个新的Target
。