将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-01-14 00:12:22

    webpack externals详解

    在众多的webpack配置教程中,对externals这个配置选项,总是一带而过,把文档中提到的几种方式都复述一遍,但是对于开发者而言,根本没法完全理解。本文试图通过一整篇文章,详细的对externals这个参数进行讲解。

  • 2020-01-14 01:06:37

    webpack externals 深入理解

    按照官方文档的解释,如果我们想引用一个库,但是又不想让webpack打包,并且又不影响我们在程序中以CMD、AMD或者window/global全局等方式进行使用,那就可以通过配置externals。这个功能主要是用在创建一个库的时候用的,但是也可以在我们项目开发中充分使用。

  • 2020-01-14 01:08:19

    webpack用externals优化echarts

    防止将某些 import 的包(package)打包到 bundle 中,而是在运行时(runtime)再去从外部获取这些扩展依赖(external dependencies)。

  • 2020-01-16 08:52:22

    Vue函数式调用组件创建公共组件

    所有组件都需要这么去调用,就会有些许麻烦而且不太美观。像Loading、Toast等这些组件,一页面可以经常用到而且每次显示的内容都可能不一样,这样的话用js的方式【this.$xxx.show(option)】去调用就方便很多,而且代码也更整洁。