java8对Map根据key排序

实际需求,针对list根据数据时间分组,分组后的map无须,但需要按照时间正序排列,代码如下

// 先根据时间分组
Map<String, List<QcDataVO>> monthList = entry.getValue().stream().collect(Collectors.groupingBy(QcDataVO::getInspectCycle));
// 分组后根据key正序排列,()LinkedHashMap有序)
			monthList = monthList.entrySet().stream().sorted(new Comparator<Map.Entry<String, List<QcDataVO>>>() {
				@Override
				public int compare(Map.Entry<String, List<QcDataVO>> o1, Map.Entry<String, List<QcDataVO>> o2) {
					try {
						Date d1 = DateUtil.convertStringToDate(o1.getKey(), "yyyy-MM");
						Date d2 = DateUtil.convertStringToDate(o2.getKey(), "yyyy-MM");
						return d1.compareTo(d2);
					} catch (Exception e) {
						e.printStackTrace();
					}
					return 0;
				}
			}).collect(Collectors.toMap(
					Map.Entry::getKey,
					Map.Entry::getValue,
					(oldVal, newVal) -> oldVal,
					LinkedHashMap::new
			));

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值