java 分组 有序集合 LinkedHashMap Object 转 ArrayList 遍历

项目中运用到分组排序,以某规则进行分组,并按照顺序显示在表格中,此处用到 LinkedHashMap这个有序HashMap,以下为实现方法

        List list=new ArrayList<>();
        list.add("A:aa");
        list.add("A:ab");
        list.add("A:ac");
        list.add("B:ad");
        list.add("B:aee");
        list.add("B:aa");
        list.add("C:aa");
        list.add("D:aa");
        list.add("D:aa");
        if (CollectionUtils.isNotEmpty(list)) {
            LinkedHashMap>> itemsList= new LinkedHashMap<>();//集合顺序与添加顺序一致
            List> titles=new ArrayList<>();
            for (String mm:list) {
                String[] itemName=mm.split(":");
                Map map=new HashMap<>();
                map.put(itemName[1],"1");//"1"是会变化的值,此处为测试,简化了
                if(itemsList.containsKey(itemName[0])){
                    itemsList.get(itemName[0]).add(map);
                }else{
                    titles=new ArrayList<>();
                    titles.add(map);
                }
                itemsList.put(itemName[0],titles);
            }
            logger.info(itemsList.toString());
            Iterator>>> iterator= itemsList.entrySet().iterator();//迭代器遍历LinkedHashMap
            while(iterator.hasNext())
            {
                Map.Entry entry = iterator.next();
                logger.info(entry.getKey()+":"+entry.getValue());
                List> listMap=(ArrayList>)entry.getValue();//object 转 ArrayList
                for(int m=0;m map=listMap.get(m);
                    for(String key:map.keySet()){//遍历 map
                        logger.info(key+" --"+map.get(key));
                    }
                }
            }
        }

打印结果如下:

java 分组 有序集合 LinkedHashMap Object 转 ArrayList 遍历_第1张图片

 

 

你可能感兴趣的:(java基础)