将list转成map,并按照另外一个list排序

需求说明:A list假如是一串编码,

通过in的sql语句可以查到一连串另外的数据(List<B> = select (A list); ),但查出来的数据(List<B>)是按数据库的自然顺序进行排序的,无法与原来的list(A List)对应,也就是说

无法做到A、B、C进去a、b、c出来,而是变成其他顺序出来,所以需要对出来的数据进行重新排序。

 

环境:java8以上

示例代码如下:

public AccountResultData accountMoneyRegion(AccountResultData accountResultData, Map<String, Object> continueMap,
			List<String> nameList, List<String> codeList, String year) {
		List<String> barAreaData = new ArrayList<>();
		Map<String, Object> map = new HashMap<>(continueMap);//创建用于查询用的map
		map.put("type", "2");//添加参数
		map.put("codeList", codeList);//这就是上面提到的A list
		map.put("time", year);
		List<TakeAccountRegion> takeAccountRegionList = takeAccountRegionMapper.selectByTypeAndCodeList(map);//将map传入sql层内查询出List<B>

//此处便出现了List<B>与A list不能一一对应的情况
//下面就是解决方法:

		Map<String,TakeAccountRegion> takeAccountRegionMap = takeAccountRegionList.stream().collect(
                Collectors.toMap(a -> a.getRegionCode(),
                        a -> a));
		for(String code:codeList) {
			barAreaData.add(MoneyUtils.matchMonmey(takeAccountRegionMap.get(code).getTotalMoneny()).toString());
		}
		accountResultData.setBarAreaData(barAreaData);
		accountResultData.setAreaYAxisData(nameList);
		return accountResultData;
	}

 

 

其中关键性的代码:

Map<String,TakeAccountRegion> takeAccountRegionMap = takeAccountRegionList.stream().collect(
                Collectors.toMap(a -> a.getRegionCode(),
                        a -> a));

怎么理解这段代码呢?首先声明了一个String,某对象(这里是:TakeAccountRegion)的map,必须保证key是唯一值:

这里就是a.getRegionCode()这里,a就是对象它本身

 

然后再通过循环,用之前的list,来从这个map里取值即可。

 

此处牵扯到了JAVA 8 新特性:Lambda表达式

关于JAVA 8 新特性 可以参考:https://blog.youkuaiyun.com/u014470581/article/details/54944384

 

当然,我是菜鸡,如果有更好的方法,请大佬们多多指导我

 

 

可以使用 Java 的 Stream API 来实现列表按某个字段分组转成 `Map` 对每个分组排序。 示例代码如下,假设列表元素是 `Map<String, Object>` 类型,按 `time` 字段分组,对每个分组按 `number` 字段排序: ```java import java.util.*; import java.util.stream.Collectors; public class ListGroupAndSort { public static void main(String[] args) { List<Map<String, Object>> mapList = new ArrayList<>(); // 初始化数据 Map<String, Object> map1 = new HashMap<>(); map1.put("number", 8); map1.put("address", "他"); map1.put("time", "2022-03-01"); mapList.add(map1); Map<String, Object> map2 = new HashMap<>(); map2.put("number", 8); map2.put("address", "他"); map2.put("time", "2022-03-04"); mapList.add(map2); // 其他数据添加... // 按 time 字段分组,对每个分组按 number 字段排序 Map<Object, List<Map<String, Object>>> groupedAndSortedMap = mapList.stream() .collect(Collectors.groupingBy(m -> m.get("time"), TreeMap::new, Collectors.toList())) .entrySet().stream() .collect(Collectors.toMap(Map.Entry::getKey, entry -> entry.getValue().stream() .sorted(Comparator.comparing(m -> (Integer) m.get("number"))) .collect(Collectors.toList()), (e1, e2) -> e1, TreeMap::new)); // 输出结果 for (Map.Entry<Object, List<Map<String, Object>>> entry : groupedAndSortedMap.entrySet()) { System.out.println("Key: " + entry.getKey()); for (Map<String, Object> map : entry.getValue()) { System.out.println(" " + map); } } } } ``` 上述代码中,首先使用 `Collectors.groupingBy` 方法按 `time` 字段对列表进行分组,得到一个 `Map`,键是 `time` 的值,值是对应分组的列表。然后,对每个分组的列表使用 `sorted` 方法按 `number` 字段进行排序。最后,将排序后的分组重新收集到一个新的 `Map` 中。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值