位置: IT常识 - 正文

[进阶] list 过滤 stream 的lambda进阶操作, 这一篇就够了(list集合过滤)

编辑:rootadmin

目录

1. list转化map基本操作

id最常用方式: 

-> 01  key-value值形式:

-> 02 id-> 对象本身

-> 03 id-> 对象本身的 lambda写法

->04  解决冲突的key

2. list计算操作

3. list转化泛型操作

4. List转成map的进阶操作

 ->4.1  有实体类的进阶操作(常用)

--->准备工作01 :  基础数据(User实体类)

--->4.1.1:  (1对1关系) 分组: 用户名-> 用户实体类对象User(String->T)

 --->4.1.2  (1对1关系) 用户名 -> 电话号(String-> String)

--->4.1.301:  (1对多) 分组01: 根据年龄分组  Integer-> List 

--->4.1.302:  (1对多) 分组01: 根据年龄分组  Integer-> List 方法二

--->4.1.4:  (1对多) 分组 根据年龄分出 年龄-> 用户 Integer -> List

-> 4.2 没有实体类的进阶操作

[待续未完....时间有限]

-> 5. 总结: 4整个的main方法

-> 5..1 不啰嗦 直接上代码


1. list转化map基本操作id最常用方式: -> 01  key-value值形式:Map<Integer,String>map = list.stream().collect(Collectors.toMap(User::getId,User::getRealName))-> 02 id-> 对象本身 Map<Integer,User> userMap3 = list.stream().collect(Collectors.toMap(User::getId, Function.identity()));-> 03 id-> 对象本身的 lambda写法Map<Integer,User> userMap2 = userList.stream().collect(Collectors.toMap(User::getId,User->User));->04  解决冲突的keyMap<Integer,User> userMap4 = userList.stream().collect(Collectors.toMap(User::getId, Function.identity(),(key1,key2)->key2));2. list计算操作List<Long> testList = new ArrayList<>(Collections.nCopies(5, 0L)); testList.set(0,1L); testList.set(1,2L); testList.set(2,3L); testList.set(3,4L); testList.set(4,5L); System.out.println("sum1 is " + testList.stream().reduce(0L, (a, b) -> a + b)); // reduce根据初始值(参数1)和累积函数(参数2)依次对数据流进行操作,第一个值与初始值送入累积函数,后面计算结果和下一个数据流依次送入累积函数。 System.out.println("sum2 is " + testList.stream().reduce(0L, Long::sum)); System.out.println("sum3 is " + testList.stream().collect(Collectors.summingLong(Long::longValue))); // Collectors.summingLong()将流中所有元素视为Long类型,并计算所有元素的总和 System.out.println("sum4 is " + testList.stream().mapToLong(Long::longValue).sum()); System.out.println("***********************"); List<Person> testList1 = new ArrayList<>(Collections.nCopies(5, new Person(1))); System.out.println("class sum1 is " + testList1.stream().map(e -> e.getAge()).reduce(0, (a,b) -> a + b)); System.out.println("class sum2 is " + testList1.stream().map(e -> e.getAge()).reduce(0, Integer::sum)); System.out.println("class sum3 is " + testList1.stream().collect(Collectors.summingInt(Person::getAge))); System.out.println("class sum4 is " + testList1.stream().map(e -> e.getAge()).mapToInt(Integer::intValue).sum());3. list转化泛型操作 List<User> list = userMapper.selectUserMessage(null); List<UserRespDTO> collect = list.stream().map(dto-> { UserRespDTO userRespDTO = new UserRespDTO(); BeanUtils.copyProperties(dto, respDTO); return userRespDTO; }).collect(Collectors.toList());4. List转成map的进阶操作 ->4.1  有实体类的进阶操作(常用)--->准备工作01 :  基础数据(User实体类)import com.fasterxml.jackson.annotation.JsonFormat;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import lombok.experimental.Accessors;import java.util.Date;/** * 模拟用户实体类对象 * * @author pzy * @version 0.1.0 */@Data@NoArgsConstructor@AllArgsConstructor@Accessors(chain = true)public class User { private String username; private Integer age; private String telephone; @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8") private Date createTime;}

推荐整理分享[进阶] list 过滤 stream 的lambda进阶操作, 这一篇就够了(list集合过滤),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:list集合过滤,java list过滤,list filter过滤,java list过滤,list filter过滤,list过滤list,list过滤list,list过滤指定条件,内容如对您有帮助,希望把文章链接给更多的朋友!

[进阶] list 过滤 stream 的lambda进阶操作, 这一篇就够了(list集合过滤)

---> 准备工作02: 

//1. 创建基础数据 List<User> list = new ArrayList<>(); User user1 = new User("张三", 33, "13345678913", new Date()); User user2 = new User("李四", 44, "13345678914", new Date()); User user3 = new User("王五", 55, "13345678915", new Date()); User user4 = new User("李六", 55, "13345678916", new Date()); list.add(user1); list.add(user2); list.add(user3); list.add(user4);--->4.1.1:  (1对1关系) 分组: 用户名-> 用户实体类对象User(String->T)Map<String, User> map1 = list.stream().collect(Collectors.toMap(User::getUsername, each -> each, (value1, value2) -> value1)); System.out.println(JSON.toJSONString(map1));

 //{"李四":{"age":44,"createTime":1679536527360,"telephone":"13345678914","username":"李四"},"张三":{"age":33,"createTime":1679536527360,"telephone":"13345678913","username":"张三"},"李六":{"age":55,"createTime":1679536527360,"telephone":"13345678916","username":"李六"},"王五":{"age":55,"createTime":1679536527360,"telephone":"13345678915","username":"王五"}}

 --->4.1.2  (1对1关系) 用户名 -> 电话号(String-> String) Map<String,String> map2 = list.stream().collect(Collectors.toMap(User::getUsername,User::getTelephone,(value1, value2) -> value1)); System.out.println(JSON.toJSONString(map2));

//{"李四":"13345678914","张三":"13345678913","李六":"13345678916","王五":"13345678915"}

--->4.1.301:  (1对多) 分组01: 根据年龄分组  Integer-> List<T> Map<Integer, List<User>> map301 = list.stream().collect(Collectors.groupingBy(User::getAge)); System.out.println(JSON.toJSONString(map301));//{33:[{"age":33,"createTime":1679536527360,"telephone":"13345678913","username":"张三"}],55:[{"age":55,"createTime":1679536527360,"telephone":"13345678915","username":"王五"},{"age":55,"createTime":1679536527360,"telephone":"13345678916","username":"李六"}],44:[{"age":44,"createTime":1679536527360,"telephone":"13345678914","username":"李四"}]}--->4.1.302:  (1对多) 分组01: 根据年龄分组  Integer-> List<T> 方法二Map<Integer,List<User>> map302 = list.stream().collect(Collectors.toMap(User::getAge, Collections::singletonList,(value1, value2) -> { List<User> union = new ArrayList<>(value1); union.addAll(value2); return union; })); System.out.println(JSON.toJSONString(map302));//{33:[{"age":33,"createTime":1679536527360,"telephone":"13345678913","username":"张三"}],55:[{"age":55,"createTime":1679536527360,"telephone":"13345678915","username":"王五"},{"age":55,"createTime":1679536527360,"telephone":"13345678916","username":"李六"}],44:[{"age":44,"createTime":1679536527360,"telephone":"13345678914","username":"李四"}]}--->4.1.4:  (1对多) 分组 根据年龄分出 年龄-> 用户 Integer -> List<String>

业务: 想查看每个年龄下都有谁(姓名即可)

Map<Integer,List<String>> map4 = list.stream().collect(Collectors.toMap(User::getAge,each->Collections.singletonList(each.getUsername()),(value1, value2) -> { List<String> usernameList = new ArrayList<>(value1); usernameList.addAll(value2); return usernameList; })); System.out.println(JSON.toJSONString(map4));//{33:["张三"],55:["王五","李六"],44:["李四"]}-> 4.2 没有实体类的进阶操作[待续未完....时间有限]-> 5. 总结: 4整个的main方法-> 5..1 不啰嗦 直接上代码 public static void main(String[] args) { //1. 创建基础数据 List<User> list = new ArrayList<>(); User user1 = new User("张三", 33, "13345678913", new Date()); User user2 = new User("李四", 44, "13345678914", new Date()); User user3 = new User("王五", 55, "13345678915", new Date()); User user4 = new User("李六", 55, "13345678916", new Date()); list.add(user1); list.add(user2); list.add(user3); list.add(user4); /*1. (1对1关系) 分组: 用户名-> 用户实体类对象User*/ Map<String, User> map1 = list.stream().collect(Collectors.toMap(User::getUsername, each -> each, (value1, value2) -> value1)); System.out.println(JSON.toJSONString(map1)); //{"李四":{"age":44,"createTime":1679536527360,"telephone":"13345678914","username":"李四"},"张三":{"age":33,"createTime":1679536527360,"telephone":"13345678913","username":"张三"},"李六":{"age":55,"createTime":1679536527360,"telephone":"13345678916","username":"李六"},"王五":{"age":55,"createTime":1679536527360,"telephone":"13345678915","username":"王五"}} /*2. (1对1关系) 用户名 -> 电话号 */ Map<String,String> map2 = list.stream().collect(Collectors.toMap(User::getUsername,User::getTelephone,(value1, value2) -> value1)); System.out.println(JSON.toJSONString(map2)); //{"李四":"13345678914","张三":"13345678913","李六":"13345678916","王五":"13345678915"} /*301. (1对多关系) 分组01: 根据年龄分组 目的: 将年龄相等的进行分组 年龄->用户实体类 */ Map<Integer, List<User>> map301 = list.stream().collect(Collectors.groupingBy(User::getAge)); System.out.println(JSON.toJSONString(map301)); //{33:[{"age":33,"createTime":1679536527360,"telephone":"13345678913","username":"张三"}],55:[{"age":55,"createTime":1679536527360,"telephone":"13345678915","username":"王五"},{"age":55,"createTime":1679536527360,"telephone":"13345678916","username":"李六"}],44:[{"age":44,"createTime":1679536527360,"telephone":"13345678914","username":"李四"}]} /*302. (1对多关系) 分组02: 根据年龄分组 目的: 将年龄相等的进行分组 年龄->用户实体类 */ Map<Integer,List<User>> map302 = list.stream().collect(Collectors.toMap(User::getAge, Collections::singletonList,(value1, value2) -> { List<User> union = new ArrayList<>(value1); union.addAll(value2); return union; })); System.out.println(JSON.toJSONString(map302)); //{33:[{"age":33,"createTime":1679536527360,"telephone":"13345678913","username":"张三"}],55:[{"age":55,"createTime":1679536527360,"telephone":"13345678915","username":"王五"},{"age":55,"createTime":1679536527360,"telephone":"13345678916","username":"李六"}],44:[{"age":44,"createTime":1679536527360,"telephone":"13345678914","username":"李四"}]} /*4. (1对多关系) 分组 根据年龄分出 年龄-> 用户 业务: 想查看每个年龄下都有谁(姓名即可)*/ Map<Integer,List<String>> map4 = list.stream().collect(Collectors.toMap(User::getAge,each->Collections.singletonList(each.getUsername()),(value1, value2) -> { List<String> usernameList = new ArrayList<>(value1); usernameList.addAll(value2); return usernameList; })); System.out.println(JSON.toJSONString(map4)); //{33:["张三"],55:["王五","李六"],44:["李四"]} }

创作不易, 点个赞再走呗~~~

本文链接地址:https://www.jiuchutong.com/zhishi/299268.html 转载请保留说明!

上一篇:基于OpenCV的人脸识别(基于opencv的人脸检测算法)

下一篇:H5项目如何打包成APP(h5项目怎么打包成app)

  • qq看点怎么关闭(QQ看点怎么关闭自动下一个视频)

  • 红米k40pro+是屏幕解锁吗(红米k40pro是屏幕指纹识别吗)

  • 红米k30s至尊纪念版支持超级壁纸吗(红米k30s至尊纪念版是什么屏幕)

  • 快手为什么播放量变少了(快手为什么播放不了)

  • 好友恢复是谁删的谁(好友恢复知道对方是谁吗)

  • 一个人可以认证几个快手号(一个人可以认证几个小红书号)

  • 该视频搬运是什么意思(视频搬运是什么意思定义)

  • 华为电脑死机怎么重启(华为电脑开机死机)

  • 淘宝与天猫的区别在哪里(淘宝和天猫的区别?)

  • 华为主要业务做什么(华为主要业务是什么)

  • macbookpro屏幕怎么清洁(macbookpro屏幕怎么样)

  • 4g手机能用5gwifi网络吗(4g手机能用5gwifi吗)

  • 连接小米助手有什么用(miui11小米助手连接不上手机)

  • 如何改善单极式极距型电容传感器的非线性(如何改善单极式变间距电容传感器的非线性)

  • 苹果7plus信号不好怎么办(苹果7plus信号不稳定)

  • opporenoz和reno有什么不同(opporenoz与opporeno)

  • 苹果xr屏幕划不动(苹果xr屏幕划不动怎么回事)

  • qq手机备忘录在哪里(qq备忘录怎么导出电话号码)

  • ios13怎么下载第三方软件(ios13.4怎么下载)

  • word怎么删除不要的表格(word怎么删除不需要的页码)

  • 网页猜你想搜怎么关闭(网页猜你想搜怎么去掉)

  • vivox27录屏怎么没有声音(vivox27录屏怎么把声音录进去)

  • 小米9透明版和透明尊享版有什么区别(小米9透明版和探索版一样吗)

  • 华为天气怎样设置为摄氏度(华为天气怎样设置常驻城市)

  • 巨人堤道上的玄武岩柱,英国北爱尔兰 (© Olimpio Fantuz/eStock Photo)(巨人堤道上的玄关图片)

  • 被称为下一代风口的AIGC到底是什么?(被称为下一代风华的是)

  • 工具篇(七)MarkDown(工具tj)

  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设 电脑维修 湖南楚通运网络