【ECharts】使用 ECharts 处理不同时间节点的数据系列展示
创始人
2025-01-07 08:34:12
0

使用 ECharts 处理不同时间节点的数据系列展示

在数据可视化中,我们经常遇到这样的问题:不同数据系列的数据点在时间轴上并不对齐。这种情况下,如果直接在 ECharts 中展示,图表可能会出现混乱或不准确。本文将通过一个示例代码,演示如何解决这一问题,使得多个数据系列在同一个图表中能够准确展示。
在这里插入图片描述

问题描述

假设我们有多个测站(stations),每个测站有多个目标(targets),每个目标在不同的时间点采集数据。为了将这些数据在同一个图表中展示,我们需要对时间点进行统一处理,使得每个时间点都有相应的数据值。具体来说,我们需要将数据重新采样到一个统一的时间轴上。

示例代码

以下代码演示了如何将不同时间节点的数据系列重新采样到统一的时间轴上,并生成新的数据结构,以便在 ECharts 中展示。

function aggregateData(stations) {     // 生成新的时间点,五分钟一个间隔     function generateTimePoints(startTime, endTime) {         let times = [];         let current = new Date(startTime);         while (current <= endTime) {             times.push(current.toTimeString().substring(0, 5));             current.setMinutes(current.getMinutes() + 5);         }         return times;     }      // 解析时间字符串为Date对象     function parseTime(timeStr) {         let parts = timeStr.split(":");         let date = new Date();         date.setHours(parseInt(parts[0]), parseInt(parts[1]), 0, 0);         return date;     }      // 初始化新的时间点     let allProduceTimes = [];     stations.forEach(station => {         station.targets.forEach(target => {             target.produceTime.forEach(time => {                 allProduceTimes.push(parseTime(time));             });         });     });      let minTime = new Date(Math.min.apply(null, allProduceTimes));     let maxTime = new Date(Math.max.apply(null, allProduceTimes));     let newProduceTimes = generateTimePoints(minTime, maxTime);      // 重新填充数据     stations.forEach(station => {         station.targets.forEach(target => {             let newData = new Array(newProduceTimes.length).fill(0);             let index = 0;              target.produceTime.forEach((time, i) => {                 let parsedTime = parseTime(time);                  while (index < newProduceTimes.length && parsedTime >= parseTime(newProduceTimes[index])) {                     index++;                 }                  if (index > 0) {                     newData[index - 1] = parseFloat(target.data[i]);                 }             });              target.produceTime = newProduceTimes;             target.data = newData.map(value => value.toFixed(1)); // 保留一位小数         });     });      return stations; }  // 示例输入 let stations = [     {         "inverterno": "2005435242250085",         "targets": [             {                 "value": "todayEnergy",                 "unit": 4,                 "data": [                     "22.3", "23.3", "24.2", "25.2", "26.1", "26.9", "27.8", "28.6", "29.3", "30.0", "30.7", "31.4", "32.0", "32.5", "33.2", "33.8", "34.4", "35.0", "35.6", "36.2"                 ],                 "produceTime": [                     "05:39", "05:44", "05:49", "05:54", "05:59", "06:04", "06:09", "06:14", "06:19", "06:24", "06:29", "06:34"                 ]             },             {                 "value": "totalEnergy",                 "unit": 4,                 "data": [                     "1797.0", "1797.0", "1798.0", "1799.0", "1799.0", "1800.0", "1801.0", "1801.0", "1802.0", "1802.0", "1803.0", "1804.0"                 ],                 "produceTime": [                     "05:39", "05:44", "05:49", "05:54", "05:59", "06:04", "06:09", "06:14", "06:19", "06:24", "06:29", "06:34"                 ]             }         ]     },     {         "inverterno": "2005435242250086",         "targets": [             {                 "value": "todayEnergy",                 "unit": 4,                 "data": [                     "0.0", "0.0", "0.0", "0.1", "0.1", "0.1", "0.1", "0.1", "0.1", "0.1", "0.2", "0.2", "0.2", "0.3", "0.4", "0.4", "0.5", "0.6", "0.7"                 ],                 "produceTime": [                     "05:27", "05:32", "05:37", "05:42", "05:47", "05:52", "05:57", "06:02", "06:07", "06:12", "06:17", "06:22"                 ]             },             {                 "value": "totalEnergy",                 "unit": 4,                 "data": [                     "1106.0", "1106.0", "1106.0", "1106.0", "1106.0", "1106.0", "1106.0", "1106.0", "1106.0", "1106.0", "1106.0", "1106.0"                 ],                 "produceTime": [                     "05:27", "05:32", "05:37", "05:42", "05:47", "05:52", "05:57", "06:02", "06:07", "06:12", "06:17", "06:22"                 ]             }         ]     } ];  let aggregatedStations = aggregateData(stations); console.log(JSON.stringify(aggregatedStations, null, 2)); 

代码详解

  1. 生成新的时间点:
    generateTimePoints函数生成一个从startTimeendTime的时间点数组,时间间隔为5分钟。这样我们可以确保所有数据系列的时间点都是对齐的。

  2. 解析时间字符串为Date对象:
    parseTime函数将时间字符串(例如"05:39")解析成Date对象,以便进行时间计算。

  3. 初始化新的时间点:
    遍历所有的测站和目标,收集所有的生产时间点,找到最小时间点和最大时间点,并生成包含所有时间点的数组newProduceTimes

  4. 重新填充数据:
    遍历每个测站和目标,将旧时间点和数据映射到新的时间点数组上。新的数据newData初始化为0数组,然后根据旧时间点填充相应的数值。

在 ECharts 中展示

现在,我们已经将数据重新采样到统一的时间轴上,接下来可以在 ECharts 中展示这些数据。以下是一个简单的 ECharts 配置示例:

var chart = echarts.init(document.getElementById('main'));  var option = {     tooltip: {         trigger: 'axis'     },     legend: {         data: ['今日能量', '总能量']     },     xAxis: {         type: 'category',         data: aggregatedStations[0].targets[0].produceTime     },     yAxis: {         type: 'value'     },     series: [         {             name: '今日能量',             type: 'line',             data: aggregatedStations[0].targets[0].data         },         {             name: '总能量',             type: 'line',             data: aggregatedStations[0].targets[1].data         },         {             name: '今日能量2',             type: 'line',             data: aggregatedStations[1].targets[0].data         },         {             name: '总能量2',             type: 'line',             data: aggregatedStations[1].targets[1].data         }     ] };  chart.setOption(option); 

相关内容

热门资讯

Midjourney教程(完整... Midjourney使用指南 - 订阅计划费用比较 Midjourney 具有三个订阅版本。按月或全...
AIGC在软件开发中的应用 目录1. AIGC技术概述1.1 定义与背景1.2 发展历程2. AIGC在软件开发中的应用2.1 ...
llama-factory微调... 一、定义环境配置案例: https://zhuanlan.zhihu.com/p/69...
基于Python热门旅游景点数... 博主介绍: ✌全网粉丝30W+,csdn特邀作者、博客专家、CSDN新星计划导...
第一方教程微扑克透明挂(微扑克... 第一方教程微扑克透明挂(微扑克)辅助挂(外挂辅助器AI代打)详细教程(2024已更新)(哔哩哔哩);...
盘点一款微扑克app原来真的是... 盘点一款微扑克app原来真的是有挂,太嚣张了原来真的有挂,详细教程(有挂头条);微扑克软件透明挂作为...
推荐十款《Wepoke网页版》... 推荐十款《Wepoke网页版》软件透明挂,Wepoke网页版透明挂程序(有挂方法);AI辅助机器人普...
重大通报《WPK辅助挂透视辅助... 重大通报《WPK辅助挂透视辅助》太坑了原来真的是有挂(有挂方法);超受欢迎的WPK稳赢小游戏,经典的...
玩家必看教程Wepoke脚本软... 《玩家必看教程Wepoke脚本软件透明挂!(辅助挂)太坑了其实是有挂的(2021已更新)(哔哩哔哩)...
2024版规律微扑克模拟器原来... 2024版规律微扑克模拟器原来真的有挂,太过分了原来确实是有挂,详细教程(今日头条);1、超多福利:...