我将两个每日统计数据集输入到我的图表中。如您所见,每个元素代表特定日期的值。

"data":[[{"y":"1",  "x":"2018-04-01T04:00:00Z"},
         {"y":"14", "x":"2018-04-02T04:00:00Z"},
         {"y":"5",  "x":"2018-04-03T04:00:00Z"},
         {"y":"7",  "x":"2018-04-04T04:00:00Z"},
         ...

x 轴定义如下:
xAxes: [{
         type: 'time',
         distribution: 'series',
         time: {
                unit: 'month'
               }
        }]

我(天真地?)认为图表会将天值汇总(汇总)到适当的月份桶中,但这不是我得到的。相反,我沿 x 轴获得了每月刻度线,但数据点以每日精度绘制在图表中。 (见截图。)

在我继续并重新处理我的数据集以手动将天数汇总到各自的月份存储桶中之前,我想听听图表实际上是否可以为我执行此操作,但我只是设置错误,或者我是否在事实上,在将数据集提供给图表进行绘图之前,需要自己处理这个总结。

谢谢你的建议!

最佳答案

我通过在底层数据集的组装过程中自己进行汇总来解决这个问题,然后将其提供给图表。

var dayDate = new Date($scope.insights.locationMetrics[lm].metricValues[metric].dimensionalValues[dim].timeDimension.timeRange.startTime);
var monthDate = dayDate.getFullYear() + "-" + (dayDate.getMonth() + 1);

var hitCount = {
    y: $scope.safeNumber($scope.insights.locationMetrics[lm].metricValues[metric].dimensionalValues[dim].value),
    x: monthDate
}
var alreadyRecorded = hits[labelIdx].findIndex(obj => obj.x == hitCount.x)

if (alreadyRecorded > -1) {
    hits[labelIdx][alreadyRecorded].y += Number(hitCount.y);
}
else {
    hits[labelIdx].push(hitCount);
}
  • 从底层数据源中提取日期
  • 从日期
  • 中提取 yyyy-mm
  • 创建 hitCount 对象
  • 检查 hitCount 对象是否已经在数组中
  • 如果对象已经在数组中,则增加数组中的 hitCount (y)。
  • 否则,将对象插入数组。
  • 10-06 05:26