最近做报表,遇到很多求和,最大最小值等相关操作,看到这个博客写的很不错,整理一下。
list集合某项最大最小值,以及求和
// 从数据库去除数据数据条数为五条
// 由于在求和的过程当中避免不了存在 null 或者 空字符串的数据
// 因此可使用filter()进行条件筛选 具体筛选条件 根据业务而定
List<Person> personList = personService.list();
Integer collect = personList.stream()
.filter(a -> a.getPersonWorkYears() != null && !a.getPersonWorkYears().equals(""))
.collect(Collectors.summingInt(Person::getPersonWorkYears));
又或者
personList.stream().mapToInt(t -> t.getPersonWorkYears()).sum()
// 求最大值 最小值将 max 函数 替换min即可
// compareTo() 方法用于将 Number 对象与方法的参数进行比较。可用于比较 Byte, Long, Integer等。
// 该方法用于两个相同数据类型的比较,两个不同类型的数据不能用此方法来比较
Integer integer = personList.stream().map(Person::getId).max(Integer::compareTo).get();
// 获取最大值或最小值的这个对象
Comparator<Person> comparator = Comparator.comparing(Person::getPersonWorkYears);
Person maxObject = personList.stream().filter(a -> a.getPersonWorkYears() !=
null).max(comparator).get();
list集合排序
// 针对personWorkYears 你的某项 排序
// 升序排序
List<Person> collect =
personList.stream().filter(a -> a.getPersonWorkYears()!=null)
.sorted(Comparator.comparingInt(Person::getPersonWorkYears))
.collect(Collectors.toList());
// 降序排序
List<Person> collect2 =
personList.stream().filter(a -> a.getPersonWorkYears()!=null)
.sorted((a,b) -> b.getPersonWorkYears() - a.getPersonWorkYears())
.collect(Collectors.toList());
// 多字段排序
List<Person> collect =
personList.stream().filter(a -> a.getPersonWorkYears()!=null)
.sorted(Comparator.comparingInt(Person::getPersonWorkYears).thenComparing(Person::getId))
.collect(Collectors.toList());
list集合去重
// 去重
List<Person> collect1 = personList.stream().distinct().collect(Collectors.toList());