首页 > 解决方案 > C#根据特定天数将日期范围分组

问题描述

我有一个日期列表:

2021/09/01
2021/09/02
2021/09/03
2021/09/04
2021/09/05
2021/09/06
2021/09/07
2021/09/08
2021/09/09
......

2021/09/29

如何将日期范围分组为 7 天?:

2021/09/01
2021/09/02
2021/09/03
2021/09/04
2021/09/05
2021/09/06
2021/09/07

2021/09/08
2021/09/09
2021/09/10
2021/09/11
2021/09/12
2021/09/13
2021/09/14

....

标签: c#datetime

解决方案


如果您的数据可能包含一个日期的空白或多个条目,您可以计算与最小日期的差异并将其用于分组,例如:

if (dates.Any()) // Min() will fail if there are no dates
{
  var minDate = dates.Min(x => x);
  var interval = 7d;
  var groups = from x in dates 
               group x by x.Subtract(minDate).TotalDays / interval 
               into g 
               select g;
}

以上样本可作为指导;您可能需要根据您的数据结构和要求对其进行调整。


推荐阅读