Java8用Stream流一行代码实现数据分组统计,排序,最大值、最小值、平均值、总数、合计

这篇具有很好参考价值的文章主要介绍了Java8用Stream流一行代码实现数据分组统计,排序,最大值、最小值、平均值、总数、合计。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Java8对数据处理可谓十分流畅,既不改变数据,又能对数据进行很好的处理,今天给大家演示下,用Java8的Stream如何对数据进行分组统计,排序,求和等

汇总统计方法

找到汇总统计的方法。这些方法属于java 8的汇总统计类。
getAverage(): 它返回所有接受值的平均值。
getCount(): 它计算所有元素的总数。
getMax(): 它返回最大值。
getMin(): 它返回最小值。
getSum(): 它返回所有元素的总和。

示例:统计用户status的最大值,最小值,求和,平均值

看官可以根据自己的需求进行灵活变通

    @GetMapping("/list")
    public void list(){
        List<InputForm> inputForms = inputFormMapper.selectList();
        Map<String, IntSummaryStatistics> collect = inputForms.stream()
            .collect(Collectors.groupingBy(InputForm::getCreateUserName, Collectors.summarizingInt(InputForm::getStatus)));

        // 对名字去重
        Set<String> collect1 = inputForms.stream().distinct().map(InputForm::getCreateUserName).collect(Collectors.toSet());

        // 遍历名字,从map中取出对应用户的status最大值,最小值,平均值。。。
        for (String s1 : collect1) {
            IntSummaryStatistics statistics1 = collect.get(s1);

            System.out.println("第一个用户的名字为====" + s1);
            System.out.println("**********************************************");
            System.out.println("status的个数为===" + statistics1.getCount());
            System.out.println("status的最小值为===" + statistics1.getMin());
            System.out.println("status的求和为===" + statistics1.getSum());
            System.out.println("status的平均值为===" + statistics1.getAverage());
            System.out.println();
            System.out.println();
        }
    }

  结果如下:

Java8用Stream流一行代码实现数据分组统计,排序,最大值、最小值、平均值、总数、合计

分组统计:

Java8用Stream流一行代码实现数据分组统计,排序,最大值、最小值、平均值、总数、合计

    @GetMapping("/list")
    public void list(){
        List<InputForm> inputForms = inputFormMapper.selectList();
        System.out.println("inputForms = " + inputForms);

        Map<String, Long> collect = inputForms.stream().collect(Collectors.groupingBy(InputForm::getCreateUserName,
            Collectors.counting()));
        
        System.out.println("collect = " + collect);
    }

其中Collectors.groupingBy(InputForm::getCreateUserName, Collectors.counting())返回的是一个Map集合,InputForm::getCreateUserName代表key,Collectors.counting()代表value,我是按照创建人的姓名进行统计

 

可以看到总共有九条数据,其中莫昀锦有两个,周亚丽有七个

如果我们想看某个部门下面有哪些数据,可以如下代码

    @GetMapping("/list")
    public Map<String, List<InputForm>> list(){
        List<InputForm> inputForms = inputFormMapper.selectList();
        System.out.println("inputForms = " + inputForms);

        Map<String, List<InputForm>> collect = inputForms.stream()
            .collect(Collectors.groupingBy(InputForm::getCreateCompanyName));

        return collect;
    }

Java8用Stream流一行代码实现数据分组统计,排序,最大值、最小值、平均值、总数、合计

 求最大值,最小值

    @GetMapping("/list")
    public Map<String, List<InputForm>> list(){
        List<InputForm> inputForms = inputFormMapper.selectList();
        System.out.println("inputForms = " + inputForms);

        Optional<InputForm> min = inputForms.stream()
            .min(Comparator.comparing(InputForm::getId));

        System.out.println("min = " + min);
        return null;
    }

Java8用Stream流一行代码实现数据分组统计,排序,最大值、最小值、平均值、总数、合计

可以看到此id是最小的,最大值雷同文章来源地址https://www.toymoban.com/news/detail-419007.html

对某个字段求最大,最小,求和,统计,计数

    @GetMapping("/list")
    public void list(){
        List<InputForm> inputForms = inputFormMapper.selectList();
        System.out.println("inputForms = " + inputForms);

        IntSummaryStatistics collect = inputForms.stream()
            .collect(Collectors.summarizingInt(InputForm::getStatus));
        double average = collect.getAverage();
        int max = collect.getMax();
        int min = collect.getMin();
        long sum = collect.getSum();
        long count = collect.getCount();
        
        System.out.println("collect = " + collect);
    }

求最大值,最小值还可以这样做

        // 求最大值
        Optional<InputForm> max = inputForms.stream().max(Comparator.comparing(InputForm::getAgency));
        if (max.isPresent()){
            System.out.println("max = " + max);
        }

        // 求最小值
        Optional<InputForm> min = inputForms.stream().min(Comparator.comparing(InputForm::getAgency));
        if (min.isPresent()){
            System.out.println("min = " + min);
        }

对某个字段求和并汇总

int sum = inputForms.stream().mapToInt(InputForm::getStatus).sum();
        System.out.println("sum = " + sum);

求某个字段的平均值

        // 求某个字段的平均值
        Double collect2 = inputForms.stream().collect(Collectors.averagingInt(InputForm::getStatus));
        System.out.println("collect2 = " + collect2);
        
        // 简化后
        OptionalDouble average = inputForms.stream().mapToDouble(InputForm::getStatus).average();
        if (average.isPresent()){
            System.out.println("average = " + average);
        }

拼接某个字段的值,可以设置前缀,后缀或者分隔符

        // 拼接某个字段的值,用逗号分隔,并设置前缀和后缀
        String collect3 = inputForms.stream().map(InputForm::getCreateUserName).collect(Collectors.joining(",", "我是前缀", "我是后缀"));
        System.out.println("collect3 = " + collect3);

根据部门进行分组,并获取汇总人数

        // 根据部门进行汇总,并获取汇总人数
        Map<String, Long> collect4 = inputForms.stream().collect(Collectors.groupingBy(InputForm::getCreateDeptName, Collectors.counting()));
        System.out.println("collect4 = " + collect4);

根据部门和是否退休进行分组,并汇总人数

        // 根据部门和是否退休进行分组,并汇总人数
        Map<String, Map<Integer, Long>> collect5 = inputForms.stream().collect(Collectors.groupingBy(InputForm::getCreateDeptName, Collectors.groupingBy(InputForm::getIsDelete, Collectors.counting())));
        System.out.println("collect5 = " + collect5);

根据部门和是否退休进行分组,并取得每组中年龄最大的人

        // 根据部门和是否退休进行分组,并取得每组中年龄最大的人
        Map<String, Map<Integer, InputForm>> collect6 = inputForms.stream().collect(
            Collectors.groupingBy(InputForm::getCreateDeptName,
                Collectors.groupingBy(InputForm::getIsDelete,
                    Collectors.collectingAndThen(
                        Collectors.maxBy(
                            Comparator.comparing(InputForm::getAge)), Optional::get))));
        System.out.println("collect6 = " + collect6);

到了这里,关于Java8用Stream流一行代码实现数据分组统计,排序,最大值、最小值、平均值、总数、合计的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 使用java8 新特性stream流对List<Map<String, Object>>集合进行遍历、过滤、查询、去重、排序、分组

    对于一个ListMapString, Object类型的数据,可以使用Java 8的新特性stream流来进行遍历、过滤、查询、去重、排序、分组等操作。 遍历: 过滤: 查询: 去重: 排序: 分组:

    2024年02月10日
    浏览(55)
  • Java解决stream流Collectors.groupingBy 分组统计可能报空指针异常

    在使用stream流的Collectors.groupingBy做分组统计时(示例代码如下) 如果统计的字段userName有null值则会报如下错误 解决方法为在统计之前增加一个filter方法将null值事先过滤掉。代码如下:

    2024年02月04日
    浏览(43)
  • 让代码变得优雅简洁的神器:Java8 Stream流式编程

    本文主要基于实际项目常用的Stream Api流式处理总结。 因笔者主要从事风控反欺诈相关工作,故而此文使用比较熟悉的三要素之一的 【手机号】黑名单 作代码案例说明。 我在项目当中,很早就开始使用Java 8的流特性进行开发了,但是一直都没有针对这块进行开发总结。这次

    2023年04月10日
    浏览(38)
  • Java8 Stream流处理树形结构数据

    参考资料 Java8新特性-使用Stream流递归实现遍历树形结构 ID为2,6,11的Menu 是 ID为1的Menu子节点 ID为3,4,5的Menu 是 ID为2的Menu子节点 💥 注意 是下面这种写法的一种更简单的写法

    2024年02月01日
    浏览(50)
  • 如何在Stream流中分组统计

    上面是今天碰到需求,之前就做过类似的分组统计,这个相对来说比较简单,统计的也少, 序号 和 总预约人数 这两部分交给前端了,不需要由后端统计,后端统计一下 预约日期 和 检查项目 和 预约人数 就行;

    2024年02月13日
    浏览(56)
  • Java8使用Stream流实现List列表简单使用

       目录 1.forEach() 2.filter(T - boolean) 3.findAny()和findFirst() 4.map(T - R) 和flatMap(T - stream) 5.distinct() 去重 6.limit(long n)和skip(long n)  7.anyMatch(T - boolean) 8.allMatch(T - boolean) 9.noneMatch(T - boolean) Java8提供了Stream(流)处理集合的关键抽象概念,Stream 使用一种类似用 SQL 语句从数据库查询数

    2023年04月27日
    浏览(87)
  • java stream实现分组BigDecimal求和,自定义分组求和

    随着微服务的发展,越来越多的sql处理被放到java来处理,数据库经常会使用到对集合中的数据进行分组求和,分组运算等等。 那怎么样使用java的stream优雅的进行分组求和或运算呢? 这里测试数据学生,年龄类型是Integer,身高类型是BigDecimal,我们分别对身高个年龄进行求和

    2024年02月01日
    浏览(42)
  • SQL实现一行数据分组后转多行多列

    在统计一些指标时,通常会有多个指标需要分组进行聚合,但是 数据源的粒度可能并非是指标分组的粒度 。举个例子,比如从访客表中提取访客的数据,每行数据有每个平台的首次访问时间;另外要做一个平台统计表,其中的一个指标统计的是各个平台近1天、7天、30天的新

    2024年02月14日
    浏览(33)
  • Java Stream流实现多字段分组groupingBy操作

    近期的项目里,遇到一个需求:对于含有多个元素的List,按照其中的某几个属性进行分组,比如Report::getPersonID、Report::getSchoolYear、Report::getDataType等字段。下面就让我们讨论一下如何比较优雅的按多字段进行分组groupingBy。 利用单个字段进行分组 如上面的Report类,如果对于其

    2024年02月07日
    浏览(55)
  • java8 列表通过 stream流 根据对象属性去重的三种实现方法

    0、User对象 1、使用filter进行去重 测试 ①、疑惑 既然 filter 里面调用的是 distinctPredicate 方法,而该方法每次都 new 一个新的 map 对象,那么 map 就是新的,怎么能做到可以过滤呢 ②、解惑 先看一下 filter 的部分实现逻辑,他使用了函数式接口 Predicate ,每次调用filter时,会使用

    2024年01月20日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包