【Java 动态数据统计图】动态数据统计思路案例(动态,排序,数组)四(116)

这篇具有很好参考价值的文章主要介绍了【Java 动态数据统计图】动态数据统计思路案例(动态,排序,数组)四(116)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

需求::前端根据后端的返回数据:画统计图;

1.动态获取地域数据以及数据中的平均值,按照平均值降序排序;
说明:
X轴是动态的,有对应区域数据则展示;
X轴 区域数据降序排序;
【Java 动态数据统计图】动态数据统计思路案例(动态,排序,数组)四(116),java,java,开发语言

代码:

	@Override
    public List<Map<String,Object>> getTimeData(HttpServletRequest request, Map<String, Object> paramMap) {
        List<Map<String,Object>> list = getCountData(request,paramMap);
        list = list.stream().filter(e -> (e.get("status").equals("关闭"))).collect(Collectors.toList());
        List<Map<String,Object>> resultList = new ArrayList<>();
        // 静态数组
        String[] reginArr = {"安徽","安顺","北京","北美","长春","长沙","成都","承德","大连","武汉"};
        int[] count = new int[reginArr.length];
        double[] processTimeCount = new double[reginArr.length];
        double[] processTimeAvg = new double[reginArr.length];
        for (int i = 0; i < list.size(); i++) {
            String processTime = String.valueOf(list.get(i).get("processTime"));
            String region = String.valueOf(list.get(i).get("region")).trim();
            if(!processTime.contains(".")){
                list.get(i).put("processTime","0.0");
            }
            String processTime2 = String.valueOf(list.get(i).get("processTime"));
            for (int j = 0; j < reginArr.length; j++) {
                if(region.equals(reginArr[j].trim())){
                    count[j] = count[j] + 1;  // 统计次数
                    processTimeCount[j] = processTimeCount[j] + Double.parseDouble(processTime2);  // 统计合并值
                }
            }
        }
        // 计算平均值
        for (int i = 0; i < processTimeCount.length; i++) {
            processTimeAvg[i] =  processTimeCount[i]/count[i];
            // double类型的数据当分母的数值趋近0的时候,返回来的数值就是一个NAN:
            if(Double.isNaN(processTimeAvg[i])){
                processTimeAvg[i] = 0.0;
            }
        }
        // 将数据封装集合
        for (int i = 0; i < reginArr.length; i++) {
            Map<String,Object> mapResult = new HashMap<>();
            String avg = String.valueOf(processTimeAvg[i]);
            mapResult.put("title",reginArr[i]);
            mapResult.put("value",avg.substring(0,avg.indexOf(".") +2));
            resultList.add(mapResult);
        }
        // 数据过滤
        List<Map<String,Object>> finalList = new ArrayList<>();
        // 过滤不需要的数据;
        for (int i = 0; i < resultList.size(); i++) {
            String value = String.valueOf(resultList.get(i).get("value"));
            if(!value.equals("0.0")){
                finalList.add(resultList.get(i));
            }
        }
        // 排序后最终输出集合:
        List<Map<String,Object>> finalList2= new ArrayList<>();
        Double[] valueSort = new Double[finalList.size()];
        String[] titleSort = new String[finalList.size()];
        // 用数组存储需要排序的元素;
        for (int i = 0; i < finalList.size(); i++) {
            valueSort[i] = Double.parseDouble(String.valueOf(finalList.get(i).get("value")));
            titleSort[i] = String.valueOf(finalList.get(i).get("title"));
        }
        // 多个数组排序;
        BubblSortUtils.bubbleSortDescMultipleDouble(valueSort,titleSort);
        // 根据排序结果封装List;
        for (int i = 0; i < valueSort.length; i++) {
            String ch = String.valueOf(titleSort[i]);
            for (int j = 0; j < finalList.size(); j++) {
                String value = String.valueOf(finalList.get(j).get("title"));
                if(ch.equals(value)){
                    finalList2.add(finalList.get(j));
                }
            }
        }
        // 添加排序字段:sortValue
        for (int i = 0; i < finalList2.size(); i++) {
            finalList2.get(i).put("sortValue",i+1);
        }
        return finalList2;
    }

Postman接口测试:
【Java 动态数据统计图】动态数据统计思路案例(动态,排序,数组)四(116),java,java,开发语言

总结: 代码中有一个地域的数组:reginArr ,如果地域字典新增,还需维护这个字典,所以还是不够灵活;参考【Java 动态数据统计图】动态数据统计思路Demo(动态,排序)三(115)和【Java代码优化】for循环,多if条件分支代码优化一(110)中的优化方案二;有更灵活计算逻辑;文章来源地址https://www.toymoban.com/news/detail-657484.html

到了这里,关于【Java 动态数据统计图】动态数据统计思路案例(动态,排序,数组)四(116)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • Apache ECharts-数据统计(详解、入门案例)

    简介:Apache ECharts 是一款基于 Javascript 的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表。 图 1.1  Apache ECharts 功能、运行环境 功能:         ECharts,一个使用 JavaScript 实现的开源可视化库,可以流畅的运行在 PC 和移动设备上,兼容当前

    2024年04月13日
    浏览(48)
  • 《SPSS统计学基础与实证研究应用精解》视频讲解:SPSS数据排序

    《SPSS统计学基础与实证研究应用精解》4.6 视频讲解 视频为 《SPSS统计学基础与实证研究应用精解》张甜 杨维忠著 清华大学出版社 一书的随书赠送视频讲解4.6节内容 。本书已正式出版上市,当当、京东、淘宝等平台热销中,搜索书名即可。本书旨在手把手教会使用SPSS撰写实

    2024年01月23日
    浏览(47)
  • Hadoop3.0大数据处理学习4(案例:数据清洗、数据指标统计、任务脚本封装、Sqoop导出Mysql)

    直播公司每日都会产生海量的直播数据,为了更好地服务主播与用户,提高直播质量与用户粘性,往往会对大量的数据进行分析与统计,从中挖掘商业价值,我们将通过一个实战案例,来使用Hadoop技术来实现对直播数据的统计与分析。下面是简化的日志文件,详细的我会更新

    2024年02月08日
    浏览(52)
  • 【案例实践】R语言多元数据统计分析在生态环境中的实践应用

    查看原文R语言生物群落分析绘图、多元统计分析、CMIP6、遥感碳储量、GEE林业、InVEST等 生态环境领域研究中常常面对众多的不同类型的数据或变量,当要同时分析多个因变量(y)时需要用到多元统计分析(multivariate statistical analysis)。多元统计分析内容丰富,应用广泛,是

    2023年04月12日
    浏览(49)
  • 【 Linux命令行与Shell脚本编程】第四章 进程管理 ,磁盘统计信息,挂载新磁盘,数据排序,数据归档

    第四章 更多命令 进程管理 磁盘统计信息 挂载新磁盘 数据排序 数据归档 4.1,监测程序 4.1.1,ps 探查进程 4.1.2,top 实时监测进程 4.1.3,kill pkill 结束进程 1,kill 命令 2,pkill 命令 4.2,检测磁盘空间 4.2.1,mount umount挂载存储设备 1. mount 命令 其他选项 2,umount 命令 4.2.2, df 命令 4.2.3, du 命令

    2023年04月24日
    浏览(53)
  • 【每日算法 && 数据结构(C++)】—— 01 | 平方值去重统计(解题思路STL法,双指针法、流程图、代码片段)

    “Success is not final, failure is not fatal: It is the courage to continue that counts.” - Winston Churchill (成功并非终点,失败并非致命:真正重要的是继续前行的勇气 - 温斯顿·丘吉尔) 给你一个整数数组,数组中的数可以是正数、负数、零,请实现一个函数,返回这个数组中所有数的平方

    2024年02月12日
    浏览(54)
  • Java项目-苍穹外卖-Day11-Apache ECharts数据统计

    主要是以下四项的统计,以不同形式的图形进行展示 自己去网站上看一哈,我不太懂前端 com.sky.controller.admin.ReportController com.sky.service.impl.ReportServiceImpl.java orderMapper orderMapper.xml Reportcontroller ReportServiceImpl orderMapper.xml reportController ReportServiceImpl orderMapper.xml

    2024年02月09日
    浏览(45)
  • 大数据(二)大数据行业相关统计数据

    目录 一、大数据相关的各种资讯 二、转载自网络的大数据统计数据 2.1、国家大数据政策 2.2、产业结构分析 2.3、应用结构分析 2.4、数据中心 2.5、云计算 1.    据IDC预测,到2025年全球 数据产生量将达到180ZB ,其中物联网设备将占据很大一部分。 2.    据Gartner预测,到2021年

    2024年02月10日
    浏览(42)
  • 【pandas基础】--数据统计

    在进行统计分析时, pandas 提供了多种工具来帮助我们理解数据。 pandas 提供了多个聚合函数,其中包括均值、标准差、最大值、最小值等等。 此外, pandas 还可以进行基于列的统计分析,例如通过 groupby() 函数对数据进行聚合,并计算每组的统计分析结果。 除了基本的统计分

    2024年02月08日
    浏览(45)
  • 用Python做数据分析之数据统计

    接下来说说数据统计部分,这里主要介绍数据采样,标准差,协方差和相关系数的使用方法。 1、数据采样 Excel 的数据分析功能中提供了数据抽样的功能,如下图所示。Python 通过 sample 函数完成数据采样。 2、数据抽样 Sample 是进行数据采样的函数,设置 n 的数量就可以了。函

    2024年02月07日
    浏览(52)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包