繁体   English   中英

如何遍历嵌套 Map <Integer, List<abc> &gt;

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM