List<Map<String,Object>>实现多字段排序

继上次实现Comparetor接口重写compare方法后,发现诸多不便,这次直接使用了Comparator实现了多字段排序(目前是三个,可以自己拓展),目前把核心代码贴在这里,方便记录,也很简单,读一下就大致知道了;


private static Collator collator = Collator.getInstance(Locale.CHINA);

/**
     * <ul>
     * <li>方法名: sortToMap</li>
     * <li>功能描述: 对数据进行排序 </li>
     * <li>创建人: yt </li>
     * <li>创建时间: 2024/1/3 17:11 </li>
     * <li>修改备注: 排序的列表字段包含一种情况:某个字段会存在两种类型的数据 数值型&'-'字符,
     * 				排序兼容:
     *              比较时将'-'字符覆盖为-9999999.9;
     *              指定需要转换数值的列名(比较时会校验),其余列不需要转换直接参与比较
     * </li>
     * </ul>
     *
     * @param report
     * @param sortingFieldList
     * @param needTransformNumFieldNames 需要转换数值的列名
     * @return java.util.List<java.util.Map < java.lang.String, java.lang.Object>>
     */
public List<Map<String, Object>> sortToMap(Report report, List<SortingField> sortingFieldList, List<String> needTransformNumFieldNames){
        List<Map<String, Object>> dataList = report.getBody();
        if (CollectionUtils.isNotEmpty(dataList)){
            if (CollectionUtils.isNotEmpty(sortingFieldList) && StringUtils.hasText(sortingFieldList.get(0).getField())){
                List<Comparator<Map<String, Object>>> comparatorList = new ArrayList<>(sortingFieldList.size());
                // 构建比较器
                for (SortingField sortingField : sortingFieldList) {
                    Comparator<Map<String, Object>> sort;
                    // 比较列是需要转换为数值型的
                    if (CollectionUtils.isNotEmpty(needTransformNumFieldNames) && needTransformNumFieldNames.contains(sortingField.getField())){
                        if ("desc".equals(sortingField.getOrder())){
                            sort = Comparator.comparing((Map<String, Object> map) ->
                                        Double.parseDouble(
                                                // 不为空的情况下,不为'-'字符 原样转换 ,'-'字符 覆盖为-9999999.8 ,否则为null覆盖为-9999999.9
                                                Objects.nonNull(map.get(sortingField.getField()))?
                                                        !"-".equals(map.get(sortingField.getField()).toString())?map.get(sortingField.getField()).toString():"-9999999.8":"-9999999.9")
                                                ,Comparator.nullsLast(Double::compareTo).reversed());
                        }else{
                            sort = Comparator.comparing((Map<String, Object> map) ->
                                        Double.parseDouble(
                                                // 不为空的情况下,不为'-'字符 原样转换 ,'-'字符 覆盖为-9999999.8 ,否则为null覆盖为-9999999.9
                                                Objects.nonNull(map.get(sortingField.getField()))?
                                                        !"-".equals(map.get(sortingField.getField()).toString())?map.get(sortingField.getField()).toString():"-9999999.8":"-9999999.9")
                                                ,Comparator.nullsLast(Double::compareTo));
                        }
                    }else{
                        // 比较列不需要转换 collator这个是中文比较器 会根据拼音首字母排序
                        if ("desc".equals(sortingField.getOrder())){
                            sort = Comparator.comparing((Map<String, Object> map) ->
                                            Objects.nonNull(map.get(sortingField.getField()))?map.get(sortingField.getField()).toString():""
                                    ,Comparator.nullsLast(collator::compare).reversed());
                        }else{
                            sort = Comparator.comparing((Map<String, Object> map) ->
                                            Objects.nonNull(map.get(sortingField.getField()))?map.get(sortingField.getField()).toString():""
                                    ,Comparator.nullsFirst(collator::compare));
                        }
                    }
                    comparatorList.add(sort);
                }
                if (comparatorList.size()==1){
                    dataList.sort(comparatorList.get(0));
                } else if (comparatorList.size()==2){
                    dataList.sort(comparatorList.get(0).thenComparing(comparatorList.get(1)));
                } else {
                    dataList.sort(comparatorList.get(0).thenComparing(comparatorList.get(1)).thenComparing(comparatorList.get(2)));
                }
            }
            return dataList;
        }
        return new ArrayList<>();
    }
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,可以使用Comparator工具类对List<Map<String, Object>>进行多字段排序。下面是一个简单的示例代码: ```java import java.util.*; public class MultiFieldSort { public static void main(String[] args) { List<Map<String, Object>> list = new ArrayList<>(); // 添加示例数据 Map<String, Object> map1 = new HashMap<>(); map1.put("name", "John"); map1.put("age", 25); map1.put("score", 80); list.add(map1); Map<String, Object> map2 = new HashMap<>(); map2.put("name", "Alice"); map2.put("age", 30); map2.put("score", 90); list.add(map2); Map<String, Object> map3 = new HashMap<>(); map3.put("name", "Bob"); map3.put("age", 20); map3.put("score", 85); list.add(map3); // 按照name字段升序,age字段降序进行排序 list.sort(Comparator.comparing((Map<String, Object> m) -> (String) m.get("name")) .thenComparing(Comparator.comparingInt((Map<String, Object> m) -> (int) m.get("age")).reversed())); // 输出排序结果 for (Map<String, Object> map : list) { System.out.println(map); } } } ``` 这段代码演示了如何对List<Map<String, Object>>进行多字段排序。首先,我们创建了一个包含多个MapList,并添加了示例数据。然后,使用Comparator.comparing方法指定要排序字段,并使用thenComparing方法指定多个字段排序顺序。在示例中,我们按照name字段进行升序排序,如果name字段相同,则按照age字段进行降序排序。最后,使用List的sort方法对List进行排序,并输出排序结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值