zoukankan      html  css  js  c++  java
  • Java8-无限流补全日期,折线图补零

    原始数据

    自2020-11-27 过去一周的数据,日期不连续

    补全日期数据,没有的日期,数据默认补0

    /**
     * 折线图数据
     *
     * @param preDate 开始日期,不传默认近一周
     * @return
     */
    public List<DailyDataChartVo> getChartData(LocalDate preDate) {
        if (Objects.isNull(preDate)) {
            preDate = LocalDate.now().minusWeeks(1);
        }
        LocalDate endDate = LocalDate.now();
        List<DailyDataChartVo> list = this.dailyDataMapper.selectChartData(preDate, endDate);
        return this.completeData(preDate, endDate, list);
    }
    
    /**
     * 补全数据
     *
     * @param preDate 开始日期
     * @param endDate 截止日期
     * @param oldList 未补全的列表
     * @return 补全后的列表
     */
    private List<DailyDataChartVo> completeData(LocalDate preDate, LocalDate endDate, List<DailyDataChartVo> oldList) {
        List<DailyDataChartVo> newList = new ArrayList<>();
        if (CollectionUtils.isEmpty(oldList)) {
            return newList;
        }
        //间隔的日期列表
        List<LocalDate> dates = this.getRangeDays(preDate, endDate);
        Map<LocalDate, DailyDataChartVo> map = oldList.stream()
                .collect(Collectors.toMap(DailyDataChartVo::getDate, Function.identity()));
        dates.forEach(c -> {
            if (map.containsKey(c)) {
                newList.add(map.get(c));
            } else {
                //没有这一天的数据,默认补0
                newList.add(new DailyDataChartVo(c, BigDecimal.ZERO));
            }
        });
        return newList;
    }
    
    /**
     * 获取间隔的日期列表
     *
     * @param preDate 开始日期
     * @param endDate 截止日期
     * @return
     */
    private List<LocalDate> getRangeDays(LocalDate preDate, LocalDate endDate) {
        List<LocalDate> dates = new ArrayList<>();
        //间隔的天数
        long betweenDays = ChronoUnit.DAYS.between(preDate, endDate);
        if (betweenDays < 1) {
            //开始日期<=截止日期
            return dates;
        }
        //创建一个从开始日期、每次加一天的无限流,限制到截止日期为止
        Stream.iterate(preDate, c -> c.plusDays(1))
                .limit(betweenDays + 1)
                .forEach(dates::add);
        return dates;
    }
    
    

    补全后的数据

    点击查看代码
    [
        {
            "date": "2020-11-20",
            "revenue": 22.88
        },
        {
            "date": "2020-11-21",
            "revenue": 93.06
        },
        {
            "date": "2020-11-22",
            "revenue": 0
        },
        {
            "date": "2020-11-23",
            "revenue": 7.99
        },
        {
            "date": "2020-11-24",
            "revenue": 0
        },
        {
            "date": "2020-11-25",
            "revenue": 50.98
        },
        {
            "date": "2020-11-26",
            "revenue": 0
        },
        {
            "date": "2020-11-27",
            "revenue": 0
        }
    ]
    
    

    核心方法

    Stream.iterate():接收一个初始元素seed,生成从seed到f的迭代流

    /**
     * @param seed 初始元素
     * @param f UnaryOperator,函数式接口,接收T类型参数,调用apply后返回T本身,应用于上一个元素以产生新元素
     */
    public static<T> Stream<T> iterate(final T seed, final UnaryOperator<T> f) {}
    
    //创建一个从开始日期、每次加一天的无限流,限制到截止日期为止
    Stream.iterate(preDate, c -> c.plusDays(1))
            .limit(betweenDays + 1)
            .forEach(dates::add);
    


    作者:cchilei

    -------------------------------------------

    个性签名:竹杖芒鞋轻胜马 一蓑烟雨任平生

    如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!

  • 相关阅读:
    css 解决fixed 布局下不能滚动的问题
    js 正则常用函数 会正则得永生
    巧用call,appl有 根据对象某一属性求最大值
    锚点 , angular 锚点 vue锚点
    css 改变浏览器滚动条的样式
    angular 常用插件集合
    angular4,angular6 父组件异步获取数据传值子组件 undefined 问题
    angular组件之间的通讯
    tomcat的配置详解:[1]tomcat绑定域名
    click 绑定(三)防止事件冒泡
  • 原文地址:https://www.cnblogs.com/cchilei/p/15493342.html
Copyright © 2011-2022 走看看