[英]How to Iterate through nested Map<Integer, List<abc>>
如何遍历嵌套的Map<Integer, List<abc>>
Class Abc {
int id ;
String name;
Date startDate;
int rowNum;
}
List<Abc> dupList = list
.stream()
.collect(Collectors.groupingBy(Abc::getRowNum))
.values()
.stream()
.filter(v-> v.size()>=2)
.flatMap(List::stream)
.collect(Collectors.toList());
Map<Integer, List<Abc>> byRows = dupList
.stream()
.collect(Collectors.groupingBy(Abc::getRowNum));
Map contains fallowing data
Key value(abc List)
rowNum: 1 rowNum: 1
startDate: 01/01/2019
endDate:12/31/2099
name: Test1
Id:101
rowNum: 1 rowNum: 1
startDate: 01/01/2020
endDate:12/31/2099
name: Test1
Id:111
rowNum: 3 rowNum: 3
startDate: 01/01/2020
endDate:12/31/2099
name: Test4
Id:342
rowNum: 3 rowNum: 3
startDate: 01/01/2020
endDate:12/31/2099
name: Test4
Id:348
现在我想打印键的值和相应的类 Abc 列表。
当我尝试打印地图时
Map<Integer, List<Abc>> collect = byRows
.entrySet()
.stream()
.collect(Collectors.toMap(Map.Entry::getKey,
Map.Entry::getValue));
System.out.println(collect);
我得到的输出为{1=[Abc@1d72673f, Abc@1cffb7e0], 3=[Abc@522530e9, Abc@58dc69f2]}
我没有从 Abc 类的 ArrayList 的嵌套循环中获取实际值。
预期输出:
I want to print startDate for each all rows
Ex: rowNum startDate
1 01/01/2019 {startDate}
01/01/2020
3 startDate: 01/01/2020
startDate: 01/01/2020
基本上,如果列表有 2 个元素,您rowNum
进行分组并进行过滤。 所以你可以一步完成这一切。 无需分组两次
Map<Integer, List<Term>> collect = list
.stream()
.collect(Collectors.groupingBy(Abc::getRowNum))
.entrySet()
.stream()
.filter(v-> v.getValue().size()>=2)
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue));
然后,如果您想从Map
打印每个元素然后使用forEach
,您仍然可能需要根据您的要求格式化数据
collect.forEach((k,v)-> {
System.out.println("RowNum is :"+k);
v.forEach(o->System.out.println(o.getStartDate()));
});
您需要覆盖 Abc 的 toString() 方法。当您调用“System.out.println”时,它会调用 toString() 方法并返回结果。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.