java~集合分组groupby的实现
对于数据聚合来说,分组操作是很常见的,在.net里有lambda和linq,而在java里也有lambda,现在我们来实现对一个集合进行分组。
一 准备工作,有两个类型
@Value class Item { private Date createAt; private int count; private BigDecimal price; } @Value class Product { private String name; private String code; private List<Item> items; }
二 为两个类型建立集合,并赋值
List<Product> products = new ArrayList<>(); products.add(new Product("apple", "1001", Arrays.asList( new Item(new Date(2018, 1, 1), 10, new BigDecimal("9.99"))))); products.add(new Product("apple", "1001", Arrays.asList( new Item(new Date(2018, 2, 1), 10, new BigDecimal("19.99"))))); products.add(new Product("apple", "1001", Arrays.asList( new Item(new Date(2018, 3, 1), 10, new BigDecimal("29.99")))));
三 使用lambda进行分组,主要对name字段进行分组,然后把结果存在一个新的集合里
Map<String, List<Product>> groupByPriceMap = products.stream().collect(Collectors.groupingBy(Product::getName)); products = new ArrayList<>(); for (Map.Entry<String, List<Product>> str : groupByPriceMap.entrySet()) { List<Item> items = new ArrayList<>(); for (Product product : str.getValue()) { items.addAll(product.getItems()); } products.add(new Product(str.getKey(), "", items)); }
四 调试代码,在断点处查看分组后的结果
五 多条件分组的实现
Function<Product, List<Object>> compositeKey = personRecord -> Arrays.asList(personRecord.getName(), personRecord.getCode()); Map<Object, List<Product>> map = products.stream().collect(Collectors.groupingBy(compositeKey));
转自 https://www.cnblogs.com/lori/p/8932891.html
本文来自博客园,作者:jevan,转载请注明原文链接:https://www.cnblogs.com/DoNetCShap/p/15630166.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 通过 API 将Deepseek响应流式内容输出到前端