项目中运用到分组排序,以某规则进行分组,并按照顺序显示在表格中,此处用到 LinkedHashMap这个有序HashMap,以下为实现方法
List<String> 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<String,List<Map<String,String>>> itemsList= new LinkedHashMap<>();//集合顺序与添加顺序一致
List<Map<String,String>> titles=new ArrayList<>();
for (String mm:list) {
String[] itemName=mm.split(":");
Map<String, String> 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<Map.Entry<String,List<Map<String,String>>>> iterator= itemsList.entrySet().iterator();//迭代器遍历LinkedHashMap
while(iterator.hasNext())
{
Map.Entry entry = iterator.next();
logger.info(entry.getKey()+":"+entry.getValue());
List<Map<String,String>> listMap=(ArrayList<Map<String,String>>)entry.getValue();//object 转 ArrayList
for(int m=0;m<listMap.size();m++){//遍历list
Map<String,String> map=listMap.get(m);
for(String key:map.keySet()){//遍历 map
logger.info(key+" --"+map.get(key));
}
}
}
}
打印结果如下: