【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); 

相关内容

热门资讯

目前!金华佛手在线辅助,乐乐围... 目前!金华佛手在线辅助,乐乐围棋入门辅助,课程教程(果然真的有挂的)-哔哩哔哩;打开点击测试直接进入...
近年来!圣游科技辅助器(辅助挂... 近年来!圣游科技辅助器(辅助挂)果然真的是有挂(必看开挂辅助软件)-哔哩哔哩;一、圣游科技辅助器有挂...
受玩家影响!约局吧透视挂下载,... 约局吧透视挂下载是一款专注玩家量身打造的游戏记牌类型软件,在约局吧透视挂下载这款游戏中我们可以记录下...
据悉!微乐小程序辅助器脚本(辅... 据悉!微乐小程序辅助器脚本(辅助挂)原来真的有挂(分析开挂辅助安装)-哔哩哔哩;1、点击下载安装,微...
据通报!悠闲卡五星辅助,四川途... 据通报!悠闲卡五星辅助,四川途游辅助软件,机巧教程(果然是真的有挂的)-哔哩哔哩>>您好:软件加13...
围绕透视问题!hhpoker德... 围绕透视问题!hhpoker德州真的假的,wejoker辅助机器人,手筋教程(原来透视有挂)-哔哩哔...
一直以来!对战互娱辅助系统,闲... 一直以来!对战互娱辅助系统,闲来辅助神器下载,要领教程(原来确实有挂的)-哔哩哔哩;无需打开直接搜索...
刚刚!顺欣茶楼辅助视频(辅助挂... 刚刚!顺欣茶楼辅助视频(辅助挂)一贯是有挂的(关于开挂辅助安装)-哔哩哔哩;超受欢迎的顺欣茶楼辅助视...
记者获悉!hhpoker万能辅... 记者获悉!hhpoker万能辅助器,wejoker辅助器怎么卖,法子教程(一直透视真的是有挂)-哔哩...
记者获悉!互游辅助脚本(辅助挂... 记者获悉!互游辅助脚本(辅助挂)原来是有挂的(盘点开挂辅助脚本)-哔哩哔哩;1、完成互游辅助脚本的残...