去除List<Map<String,Object>>中的map中的重复值

本文介绍了一段使用Java实现的去除重复数据的方法,通过遍历List并使用Map存储唯一值来达到目的。
package ryj;


import java.util.*;


public class _1 {


    /**
     * @param args
     */
    @SuppressWarnings({"rawtypes", "unchecked"})
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Map<String, Map> msp = new HashMap<String, Map>();
        List<Map<String, Object>> list = new ArrayList<Map<String, Object>>();
        List<Map<String, Object>> listMap = new ArrayList<Map<String,Object>>();
        Map<String, Object> map1 = new HashMap<String, Object>();
        map1.put("COL0", "1");
        map1.put("name", "11");
        Map<String, Object> map2 = new HashMap<String, Object>();
        map2.put("COL0", "2");
        map2.put("name", "11");
        Map<String, Object> map3 = new HashMap<String, Object>();
        map3.put("COL0", "3");
        map3.put("name", "11");
        Map<String, Object> map4 = new HashMap<String, Object>();
        map4.put("COL0", "4");
        map4.put("name", "44");
        Map<String, Object> map5 = new HashMap<String, Object>();
        map5.put("COL0", "5");
        map5.put("name", "55");
        Map<String, Object> map6 = new HashMap<String, Object>();
        
        map6.put("COL0", "5");
        map6.put("name", "55");
        Map<String, Object> map7 = new HashMap<String, Object>();
        map7.put("COL0", "6f");
        map7.put("name", "66");
        Map<String, Object> map8 = new HashMap<String, Object>();
        map8.put("COL0", "6");
        map8.put("name", "77");
        Map<String, Object> map9 = new HashMap<String, Object>();
        map9.put("COL0", "8");
        map9.put("name", "f1");
        
        list.add(map1);
        list.add(map3);
        list.add(map2);
        list.add(map4);
        list.add(map5);
        list.add(map6);
        list.add(map7);
        list.add(map8);
        list.add(map9);
        
        System.out.println("初始数据:" + list.toString());
        
        //把list中的数据转换成msp,去掉同一COL0值多余数据,保留查找到第一个COL0值对应的数据
        for(int i = list.size()-1 ; i>=0; i--){
            Map map = list.get(i);
            String COL0 = (String)map.get("COL0");
            map.remove("COL0");
            msp.put(COL0, map);
        }
         //把msp再转换成list,就会得到根据某一字段去掉重复的数据的List<Map>
        Set<String> mspKey = msp.keySet();
        for(String key: mspKey){
            Map newMap = msp.get(key);
            newMap.put("COL0", key);
            listMap.add(newMap);
        }
        list=listMap;
        System.out.println("去掉重复数据后的数据:" + list.toString());
    }
}
在 Java 中,要对 `List<Map<String, Object>>` 类型的 `newColumnList` 进行过滤,可以根据特定的键值组合来判断两个 `Map` 是否复。以下是几种实现方法: #### 方法一:使用 Java 8 的 Stream API ```java import java.util.*; import java.util.stream.Collectors; public class ListMapDuplicateFilter { public static List<Map<String, Object>> filterDuplicates(List<Map<String, Object>> newColumnList, String... keys) { return newColumnList.stream() .collect(Collectors.collectingAndThen( Collectors.toMap( map -> Arrays.stream(keys) .map(map::get) .collect(Collectors.toList()), map -> map, (existing, replacement) -> existing ), map -> new ArrayList<>(map.values()) )); } public static void main(String[] args) { List<Map<String, Object>> newColumnList = new ArrayList<>(); Map<String, Object> map1 = new HashMap<>(); map1.put("id", 1); map1.put("name", "John"); newColumnList.add(map1); Map<String, Object> map2 = new HashMap<>(); map2.put("id", 1); map2.put("name", "John"); newColumnList.add(map2); Map<String, Object> map3 = new HashMap<>(); map3.put("id", 2); map3.put("name", "Jane"); newColumnList.add(map3); List<Map<String, Object>> filteredList = filterDuplicates(newColumnList, "id", "name"); System.out.println(filteredList); } } ``` 上述代码定义了一个 `filterDuplicates` 方法,它接受一个 `List<Map<String, Object>>` 和一组键名作为参数。使用 Java 8 的 Stream API 和 `Collectors.toMap` 方法,根据指定的键值组合来判断 `Map` 是否复,从而实现过滤。 #### 方法二:传统的迭代方式 ```java import java.util.*; public class ListMapDuplicateFilterTraditional { public static List<Map<String, Object>> filterDuplicatesTraditional(List<Map<String, Object>> newColumnList, String... keys) { List<Map<String, Object>> result = new ArrayList<>(); Set<List<Object>> seen = new HashSet<>(); for (Map<String, Object> map : newColumnList) { List<Object> keyValues = new ArrayList<>(); for (String key : keys) { keyValues.add(map.get(key)); } if (seen.add(keyValues)) { result.add(map); } } return result; } public static void main(String[] args) { List<Map<String, Object>> newColumnList = new ArrayList<>(); Map<String, Object> map1 = new HashMap<>(); map1.put("id", 1); map1.put("name", "John"); newColumnList.add(map1); Map<String, Object> map2 = new HashMap<>(); map2.put("id", 1); map2.put("name", "John"); newColumnList.add(map2); Map<String, Object> map3 = new HashMap<>(); map3.put("id", 2); map3.put("name", "Jane"); newColumnList.add(map3); List<Map<String, Object>> filteredList = filterDuplicatesTraditional(newColumnList, "id", "name"); System.out.println(filteredList); } } ``` 此代码通过传统的迭代方式,使用一个 `HashSet` 来记录已经出现过的键值组合,从而实现过滤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值