对齐多系列图表:生成完整的日期范围
创建多系列图表通常会带来挑战:不同的数据系列在同一时间范围内可能具有不一致的数据间隔,从而导致图表不对齐。 为了解决这个问题,我们需要一个涵盖整个范围的完整日期列表,无论数据差距如何。这可确保正确对齐并允许对丢失的数据点进行零填充。
方法一:优雅的 LINQ 解决方案
这种简洁的 LINQ 方法可以有效地生成所需的日期列表:
<code class="language-csharp">Enumerable.Range(0, 1 + end.Subtract(start).Days) .Select(offset => start.AddDays(offset)) .ToArray();</code>
此代码首先创建一个整数序列,表示距开始日期的日期偏移量。然后,它将每个偏移量添加到开始日期,生成一个包含指定范围内的每个日期的数组。
方法二:迭代For循环
或者,for
循环提供了更明确的逐步方法:
<code class="language-csharp">var dates = new List<DateTime>(); for (var dt = start; dt <= end; dt = dt.AddDays(1)) { dates.Add(dt); }</code>
此循环每天迭代,将每个日期添加到列表中,直到到达结束日期。
用默认值填充空白
要处理丢失的数据,请使用字典将完整范围内的每个日期映射到其相应的值(如果日期不存在,则使用默认值):
<code class="language-csharp">var paddedSeries = fullDates.ToDictionary(date => date, date => timeSeries.ContainsKey(date) ? timeSeries[date] : defaultValue);</code>
这里,fullDates
是完整的日期列表。 如果 timeSeries
包含给定日期的值,则使用该值;否则,defaultValue
被分配。 这可确保所有日期都出现在最终系列中。
以上是如何生成两个日期之间的综合日期列表以进行多系列图形对齐?的详细内容。更多信息请关注PHP中文网其他相关文章!