java8 List的Stream流操作 (实用篇 三)

ops/2024/9/22 16:14:05/

目录

Stream%E6%B5%81%E6%93%8D%E4%BD%9C%20(%E5%AE%9E%E7%94%A8%E7%AF%87%20%E4%B8%89)-toc" style="margin-left:0px;">java8 List的Stream流>Stream流操作 (实用篇 三)

初始数据

Stream%E8%BF%87%E6%BB%A4%EF%BC%9A-toc" style="margin-left:40px;">1、Stream过滤:

过滤-常用方法

1.1 筛选单元素--年龄等于18

1.2 筛选单元素--年龄大于18

1.3 筛选范围--年龄大于18 and 年龄小于40

1.4 多条件筛选--年龄大于18 or 年龄小于40 and sex==男

1.5 多条件筛选--年龄大于18 or 年龄小于40 and sex==男 返回姓名(name)集合

Stream%E5%8E%BB%E9%87%8D%EF%BC%88%E9%9B%86%E5%90%88%E5%8E%BB%E9%87%8D%E5%92%8C%E6%8C%89%E5%85%83%E7%B4%A0%E5%8E%BB%E9%87%8D%EF%BC%89-toc" style="margin-left:40px;">2、Stream去重(集合去重和按元素去重)

去重-常用方法(关键字distinct、concat和利用set、map)

2.1 关键字distinct去重

2.2 关键字concat合并和distinct 去重

2.3 用set集合去重

2.4 用map去重--以某个元素去重

Stream%E6%8B%BC%E6%8E%A5%EF%BC%88joining%EF%BC%89-toc" style="margin-left:40px;">3、Stream拼接(joining)

拼接-常用方法

3.1 集合内某个字段拼接

3.2 对象内的指定元素map拼接、返回集合

3.3 对象内的指定元素map拼接、再全部拼接

Stream%E5%88%86%E7%BB%84%E5%8D%B3%E7%BB%84%E8%A3%85%E6%88%90map(groupingBy%E3%80%81toMap)-toc" style="margin-left:40px;">4、Stream分组即组装成map(groupingBy、toMap)

分组-常用方法

4.1 groupingBy-通过年龄分组

list%E5%AF%B9%E8%B1%A1%EF%BC%8C%E5%AF%B9%E5%BA%94id%E7%9A%84%E5%AF%B9%E8%B1%A1%E7%9A%84%E6%9F%90%E4%B8%AA%E5%B1%9E%E6%80%A7%E6%88%90%E7%BB%84(%E8%BF%99%E9%87%8C%E7%94%A8%E7%9A%84userName)-toc" style="margin-left:120px;">4.2 根据userId组装list对象,对应id的对象的某个属性成组(这里用的userName)

4.3 toMap-通过userId分组(key重复会报错)

4.4 toMap-通过age分组、取前面的值

4.5 toMap-通过age分组、取后面的值

4.6 toMap-通过男女分组、并且累加age

Stream%E6%8E%92%E5%BA%8F%EF%BC%9A-toc" style="margin-left:40px;">5、Stream排序:

排序-常用方法

5.1 compareTo 关键字

5.2 Comparator.comparing() 关键方法

5.2.1 排序通常和过滤一起使用、如果元素为空会报错

5.2.2 多个元素排序方法

5.3 自定义排序

Stream%E7%BB%9F%E8%AE%A1%EF%BC%88count%E3%80%81sum%E3%80%81max%E3%80%81min%E3%80%81average%EF%BC%89-toc" style="margin-left:40px;">6、Stream统计(count、sum、max、min、average)

统计-常用方法

6.1 count-获取user集合中年龄大于18岁的人数

6.2 sum-获取user集合中所有人的年纪的总和

6.3 max-获取user集合中所有人年纪最大的人

6.4 min-获取user集合中所有人年纪最小的人

6.5 average-获取user集合中所有人的年纪的平均值

Stream%E5%88%86%E9%A1%B5%EF%BC%88skip%E3%80%81limit%EF%BC%89-toc" style="margin-left:40px;">7、Stream分页(skip、limit)

分页-常用方法

7.1 skip:跳过前n个数据 、limit:获取前n个数据


Stream%E6%B5%81%E6%93%8D%E4%BD%9C%20(%E5%AE%9E%E7%94%A8%E7%AF%87%20%E4%B8%89)">java8 List的Stream流>Stream流操作 (实用篇 三)

实际开发的时候想不起来Stream的一些常用方法、去找却很不方便、所以我准备再学一篇实用或者叫常用的stream相关方法的文章。学习整理也是方便查看

结合 java8 List的Stream流>Stream流操作 (常用篇 一)_java list.stream-CSDN博客

java8 List的Stream流>Stream流操作 (特别篇 二) toMap_java list tomap-CSDN博客

和实际开发中的需求、按开发使用率排

初始数据

        List<User> userList = Lists.newArrayList();userList.add(new User(1,"天一","男",16,true));userList.add(new User(2,"空二","女",19,true));userList.add(new User(3,"张三","男",18,true));userList.add(new User(4,"李四","女",38,true));userList.add(new User(5,"王五","男",18,true));userList.add(new User(6,"王六","男",18,true));userList.add(new User(7,"王七","男",18,true));userList.add(new User(7,"王七","男",18,true));userList.add(new User(8,"王七","男",null,true));

Stream%E8%BF%87%E6%BB%A4%EF%BC%9A">1、Stream过滤:

过滤是我们基本必用的 不管是过滤null值还是按条件过滤都是最常用的。

过滤-常用方法

1.1 筛选单元素--年龄等于18
//筛选单元素--年龄等于18
List<User> filterAgeEqual = userList.stream().filter(user -> user.getAge() == 18).collect(Collectors.toList());
1.2 筛选单元素--年龄大于18
//筛选单元素--年龄大于18
List<User> filterAgeRange = userList.stream().filter(user -> user.getAge() > 18).collect(Collectors.toList());
1.3 筛选范围--年龄大于18 and 年龄小于40
//筛选范围--年龄大于18 and 年龄小于40
List<User> filterAgeRange2 = userList.stream().filter(user -> user.getAge() > 18 && user.getAge() < 40).collect(Collectors.toList());
1.4 多条件筛选--年龄大于18 or 年龄小于40 and sex==男
//多条件筛选--年龄大于18 or 年龄小于40 and sex==男
List<User> filterAgeRange3 = userList.stream().filter(user -> user.getAge() > 18 || user.getAge() < 40 && "男".equals(user.getSex())).collect(Collectors.toList());
1.5 多条件筛选--年龄大于18 or 年龄小于40 and sex==男 返回姓名(name)集合
//多条件筛选--年龄大于18 or 年龄小于40 and sex==男  返回姓名(name)集合
List<String> nameList = userList.stream().filter(user -> (user.getAge() > 18 || user.getAge() < 40) && "男".equals(user.getSex())).map(User::getUserName).collect(Collectors.toList());

Stream%E5%8E%BB%E9%87%8D%EF%BC%88%E9%9B%86%E5%90%88%E5%8E%BB%E9%87%8D%E5%92%8C%E6%8C%89%E5%85%83%E7%B4%A0%E5%8E%BB%E9%87%8D%EF%BC%89">2、Stream去重(集合去重和按元素去重)

去重-常用方法(关键字distinct、concat和利用set、map)

2.1 关键字distinct去重

集合内的对象去重--结果是有序的

List<User> distinctList = userList.stream().distinct().collect(Collectors.toList());
2.2 关键字concat合并和distinct 去重

concat:合并两个流 distinct:去重

//concat:合并两个流 distinct:去重
List<User> concatAnddistinctList = Stream.concat(userList.stream(), userList.stream()).distinct().collect(Collectors.toList());
2.3 用set集合去重

集合内的对象去重--结果乱序

//集合内的对象去重--结果乱序
Set<User> setDistinct = userList.stream().collect(Collectors.toSet());
2.4 用map去重--以某个元素去重

以某个元素去重--用map集合 (v1, v2) -> v1 使用v1是表示保留age(年龄)第一次出现的对象、如果使用v2是保留age(年龄)最后一次出现的对象

List<User> mapDistinct = userList.stream().collect(Collectors.collectingAndThen(Collectors.toMap(User::getAge, Function.identity(), (v1, v2) -> v1),map -> new ArrayList<>(map.values())));

Stream%E6%8B%BC%E6%8E%A5%EF%BC%88joining%EF%BC%89">3、Stream拼接(joining)

拼接-常用方法

3.1 集合内某个字段拼接

姓名以,拼接

//姓名以,拼接
String userNameList = userList.stream().map(User::getUserName).collect(Collectors.joining(","));
3.2 对象内的指定元素map拼接、返回集合

每个对象都以 userId-userName-age 拼接、然后返回String集合

//每个对象都以 userId-userName-age 拼接、然后返回String集合
List<String> strList = userList.stream().map((User user) -> user.getUserId() + "-" + user.getUserName() + "-" + user.getAge()).collect(Collectors.toList());
3.3 对象内的指定元素map拼接、再全部拼接

每个对象都以 userId-userName-age 拼接、再以 , 拼接返回字符串

//每个对象都以 userId-userName-age 拼接、再以 , 拼接返回字符串
String userIdAndAgeNameAndList = userList.stream().map((User user) -> user.getUserId() + "-" + user.getUserName() + "-" + user.getAge()).collect(Collectors.joining(","));

Stream%E5%88%86%E7%BB%84%E5%8D%B3%E7%BB%84%E8%A3%85%E6%88%90map(groupingBy%E3%80%81toMap)">4、Stream分组即组装成map(groupingBy、toMap)

分组-常用方法

4.1 groupingBy-通过年龄分组
//groupingBy-通过年龄分组
Map<Integer, List<User>> userGroupingByMap = userList.stream().collect(Collectors.groupingBy(User::getAge));userGroupingByMap.forEach((k, v) -> {System.out.println(k + ":" + v);});
list%E5%AF%B9%E8%B1%A1%EF%BC%8C%E5%AF%B9%E5%BA%94id%E7%9A%84%E5%AF%B9%E8%B1%A1%E7%9A%84%E6%9F%90%E4%B8%AA%E5%B1%9E%E6%80%A7%E6%88%90%E7%BB%84(%E8%BF%99%E9%87%8C%E7%94%A8%E7%9A%84userName)">4.2 根据userId组装list对象,对应id的对象的某个属性成组(这里用的userName)
//根据userId组装list对象,对应id的对象的某个属性成组(这里用的userName)
Map<Integer,List<String>> mp6 = userList.stream().collect(Collectors.groupingBy(User::getUserId, Collectors.mapping(User::getUserName, Collectors.toList())));
4.3 toMap-通过userId分组(key重复会报错)
//toMap-通过userId分组(key重复会报错)
Map<Integer, User> userToMap = userList.stream().filter(user -> user.getAge() != null).collect(Collectors.toMap(User::getUserId, Function.identity()));
4.4 toMap-通过age分组、取前面的值
//toMap-通过age分组、取前面的值
Map<Integer, User> userToMap2 = userList.stream().filter(user -> user.getAge() != null).collect(Collectors.toMap(User::getAge, Function.identity(), (v1, v2) -> v1));
4.5 toMap-通过age分组、取后面的值
//toMap-通过age分组、取后面的值
Map<Integer, User> userToMap3 = userList.stream().filter(user -> user.getAge() != null).collect(Collectors.toMap(User::getAge, Function.identity(), (v1, v2) -> v2));
4.6 toMap-通过男女分组、并且累加age
//toMap-通过男女分组、并且累加age
Map<String, Integer> userToMap4 = userList.stream().filter(user -> user.getAge() != null).collect(Collectors.toMap(User::getSex, User::getAge, (v1, v2) -> v1 + v2));
userToMap4.forEach((k, v) -> {System.out.println(k + ":" + v);
});

Stream%E6%8E%92%E5%BA%8F%EF%BC%9A">5、Stream排序:

开发中有很多都是组装的集合、而要求返回的集合是有序的 (使用率不高的原因是数据库查询支持排序)、

排序-常用方法

单元素排序方法

5.1 compareTo 关键字

(o1, o2) -> o1.getUserId().compareTo(o2.getUserId()) 升序 (o1, o2) -> o2.getUserId().compareTo(o1.getUserId()) 降序

通过指定的userId字段排序

//升序 只写sorted()默认是升序、 我是为了演示才写完整的、开发中可以直接写sorted()
List<User> sortedCompareTo = userList.stream().sorted((o1, o2) -> o1.getUserId().compareTo(o2.getUserId())).collect(Collectors.toList());//降序
List<User> sortedReversed= userList.stream().sorted((o1, o2) -> o2.getUserId().compareTo(o1.getUserId())).collect(Collectors.toList());
5.2 Comparator.comparing() 关键方法

默认升序 加reversed()为降序

//默认升序
List<User> sortedComparator = userList.stream().sorted(Comparator.comparing(User::getUserId)).collect(Collectors.toList());//reversed()为降序
List<User> sortedComparatorReversed = userList.stream().sorted(Comparator.comparing(User::getUserId).reversed()).collect(Collectors.toList());
5.2.1 排序通常和过滤一起使用、如果元素为空会报错
//排序通常和过滤一起使用、如果元素为空会报错
List<User> sortedFilter = userList.stream().filter(user -> user.getAge() != null).sorted(Comparator.comparing(User::getAge)).collect(Collectors.toList());
5.2.2 多个元素排序方法

排序通常和过滤一起使用、 先用age排序、年龄相同再用userId排序(默认是升序)

//排序通常和过滤一起使用、 先用age排序、年龄相同再用userId排序(默认是升序)
Stream<User> sortedComparators = userList.stream().filter(user -> user.getAge() != null).sorted(Comparator.comparing(User::getAge).thenComparing(User::getUserId));

排序通常和过滤一起使用、 先用age排序升序、年龄相同再用userId排序降序

//排序通常和过滤一起使用、 先用age排序升序、年龄相同再用userId排序降序
Stream<User> sortedComparatorReverseds = userList.stream().filter(user -> user.getAge()!=null).sorted(Comparator.comparing(User::getAge).thenComparing(User::getUserId).reversed());
5.3 自定义排序

先按年龄再按userId自定义排序(降序)

//先按年龄再按userId自定义排序(降序)
List<User> sortedCustom = userList.stream().sorted((u1, u2) -> {if (Objects.equals(u1.getAge(), u2.getAge())) {return u2.getAge() - u1.getAge();} else {return u2.getUserId() - u1.getUserId();}
}).collect(Collectors.toList());

Stream%E7%BB%9F%E8%AE%A1%EF%BC%88count%E3%80%81sum%E3%80%81max%E3%80%81min%E3%80%81average%EF%BC%89">6、Stream统计(count、sum、max、min、average)

统计-常用方法

6.1 count-获取user集合中年龄大于18岁的人数
//count-获取user集合中年龄大于18岁的人数
Long count = userList.stream().filter(user->user.getAge() > 18).count();
System.out.println("user集合中年龄大于18岁的人数:"+count);
6.2 sum-获取user集合中所有人的年纪的总和
//sum-获取user集合中所有人的年纪的总和
Long summingLong = userList.stream().map(User::getAge).collect(Collectors.summingLong(Integer::longValue));
System.out.println("user集合中所有人的年纪的总和:"+summingLong);
6.3 max-获取user集合中所有人年纪最大的人
//max-获取user集合中所有人年纪最大的人
Optional<User> max = userList.stream().max(Comparator.comparing(User::getAge));
System.out.println("user集合中年纪最大的人是:"+max.get().getUserName());
6.4 min-获取user集合中所有人年纪最小的人
//min-获取user集合中所有人年纪最小的人
Optional<User> min = userList.stream().min(Comparator.comparing(User::getAge));
System.out.println("user集合中年纪最小的人是:"+min.get().getUserName());
6.5 average-获取user集合中所有人的年纪的平均值
//average-获取user集合中所有人的年纪的平均值
Double average = userList.stream().map(User::getAge).collect(Collectors.averagingDouble(Integer::doubleValue));
System.out.println("user集合中所有人的年纪的平均值:"+ average);

Stream%E5%88%86%E9%A1%B5%EF%BC%88skip%E3%80%81limit%EF%BC%89">7、Stream分页(skip、limit)

分页-常用方法

7.1 skip:跳过前n个数据 、limit:获取前n个数据
//skip:跳过前n个数据 、limit:获取前n个数据
List<User> skipAndLimit = userList.stream().skip(1).limit(2).collect(Collectors.toList());
if(!CollectionUtils.isEmpty(skipAndLimit)){skipAndLimit.forEach(System.out::println);
}


http://www.ppmy.cn/ops/51905.html

相关文章

Vue70-路由的几个注意点

一、路由组件和一般组件 1-1、一般组件 1-2、路由组件 不用写组件标签。靠路由规则匹配出来&#xff0c;由路由器渲染出来的组件。 1-3、注意点1 一般组件和路由组件&#xff0c;一般放在不同的文件夹&#xff0c;便于管理。 一般组件放在components文件夹下。 1-4、注意点…

在 macOS 上使用 Homebrew 安装和配置 Python 及 Tk 库

在 macOS 上&#xff0c;系统自带的 /usr/bin/python3 版本较旧&#xff0c;且直接升级系统自带的 Python 版本可能会影响系统稳定性。因此&#xff0c;推荐使用 Homebrew 来安装和管理 Python 及其相关库。本文将详细介绍如何通过 Homebrew 安装和配置 Python 3 及 Tk 库&…

Swift开发——输出格式化字符

Swift语言是开发iOS和macOS等Apple计算机和移动设备系统应用程序的官方语言。Swift语言是一种类型安全的语言,语法优美自然,其程序从main.swift文件开始执行,程序代码按先后顺序执行,同一个工程的程序文件中的类和函数直接被main.swift文件调用,除了main.swift文件外,工程…

仲恺ZK——信计专业《软件体系结构》24年试卷回忆

以下是我在总结的复习内容&#xff0c;有需要可以参考借鉴一下。我的主页还有另外一篇复习总结《仲恺ZK——信计专业《软件体系结构》&#xff0c;两者结合起来复习&#xff0c;帮助你轻松过考试&#x1f60a;。总的来说&#xff0c;考试不会太难&#xff0c;只要你了解了各类设…

VOC数据集

VOC&#xff08;Visual Object Classes&#xff09;格式的数据集是一种用于计算机视觉任务的标准数据集格式&#xff0c;它最初是由Pascal VOC&#xff08;PASCAL Visual Object Classes&#xff09;数据集引入的。VOC数据集格式定义了一套标准化的数据集结构&#xff0c;包括X…

Python批量保存Excel文件中的图表为图片

Excel工作簿作为一款功能强大的数据处理与分析工具&#xff0c;被广泛应用于各种领域&#xff0c;不仅能够方便地组织和计算数据&#xff0c;还支持用户创建丰富多彩的图表&#xff0c;直观展示数据背后的洞察与趋势。然而&#xff0c;在报告编制、网页内容制作或分享数据分析成…

关于http协议中的各种请求头、请求类型的作用以及用途

在HTTP协议中&#xff0c;请求头&#xff08;HTTP Headers&#xff09;用于在客户端&#xff08;如浏览器或其他HTTP客户端&#xff09;和服务器之间传递附加的信息。不同的请求头有不同的作用和用途&#xff0c;它们在HTTP请求的不同类型&#xff08;如GET、POST、PUT等&#…

Java——IDEA使用

一、IDEA介绍 IntelliJ IDEA 是 JetBrains 公司开发的一款功能强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;主要用于 Java 编程语言&#xff0c;但也支持多种其他语言和框架。由于其强大的功能和灵活性&#xff0c;IntelliJ IDEA 被广泛应用于软件开发领域&…