将List中的实体按照某个字段进行分组的算法

2018-03-12 16:46:23

使用语言:JAVA


如何将List中存放的实体按照某个字段进行分组呢?来看看下面的例子,假如实体中有个字段叫批次号,我们将具有相同批次号的实体放在一起,那么怎么实现呢?看下面的代码:


可以定义个Map,Map的key用于存放异常批次号,value存放实体集合List<TmExcpNewVo>。循环要排序的List



[java] view plain copy

  1. /** 

  2.  * 按照异常批次号对已开单数据进行分组 

  3.  * @param billingList 

  4.  * @return 

  5.  * @throws Exception 

  6.  */  

  7. private Map<String, List<TmExcpNewVo>> groupBillingDataByExcpBatchCode(List<TmExcpNewVo> billingList) throws Exception{  

  8.     Map<String, List<TmExcpNewVo>> resultMap = new HashMap<String, List<TmExcpNewVo>>();  

  9.       

  10.     try{  

  11.         for(TmExcpNewVo tmExcpNew : billingList){  

  12.               

  13.             if(resultMap.containsKey(tmExcpNew.getExcpbatch())){//map中异常批次已存在,将该数据存放到同一个key(key存放的是异常批次)的map中  

  14.                 resultMap.get(tmExcpNew.getExcpbatch()).add(tmExcpNew);  

  15.             }else{//map中不存在,新建key,用来存放数据  

  16.                 List<TmExcpNewVo> tmpList = new ArrayList<TmExcpNewVo>();  

  17.                 tmpList.add(tmExcpNew);  

  18.                 resultMap.put(tmExcpNew.getExcpbatch(), tmpList);  

  19.                   

  20.             }  

  21.   

  22.         }  

  23.           

  24.     }catch(Exception e){  

  25.         throw new Exception("按照异常批次号对已开单数据进行分组时出现异常", e);  

  26.     }  

  27.       

  28.     return resultMap;  

  29. }  


  • 2020-04-01 10:21:20

    Vue extend $mount 构造器详解

    本节介绍两个 Vue.js 内置但却不常用的 API——extend 和 $mount,它们经常一起使用。不常用,是因为在业务开发中,基本没有它们的用武之地,但在独立组件开发时,在一些特定的场景它们是至关重要的。

  • 2020-04-01 15:36:52

    CSS3中的transition属性详解

    transition: property duration timing-function delay transition属性是个复合属性,她包括以下几个子属性: transition-property :规定设置过渡效果的css属性名称 transition-duration :规定完成过渡效果需要多少秒或毫秒 transition-timing-function :指定过渡函数,规定速度效果的速度曲线 transition-delay :指定开始出现的延迟时间

  • 2020-04-02 17:02:25

    vue怎么能像jquery那样获得数据

    有时候我们需要获得动态的元素,但是我们没法直接用vue语法,vue一共了当前组件的对象,我们可以避免使用document.get...之类的。