如何解决如何按日期范围对列表进行分组
|| 我想按日期或季度对DateRange列表中的持续时间求和。 我不确定采用最佳方法。 List<Event> events = new List<Event>();
class Event
{
public string EventName {get;set;}
public DateTime date {get;set;}
public double duration {get; set;}
}
我正在使用LingBridge库,该库将允许在.net-2.0中使用lambda表达式
解决方法
您将需要使用
for
或foreach
或类似的对象遍历集合。
以Q1为例:
List<Event> Q1Events = new List<Event>();
foreach (Event e in events)
{
if (e.date.Month >= 1 && e.date.Month <= 3)
Q1Events.Add(e);
}
,这是一些与2.0兼容的代码,可以实现对日期的分组。您可以对其进行调整,以根据类的DateTime
属性进行分组。
List<DateTime> dates = ...
Dictionary<int,IList<DateTime>> groupedDates
= new Dictionary<int,IList<DateTime>>();
foreach (DateTime date in dates)
{
int quarter = (date.Month / 3) + 1;
if (groupedDates.ContainsKey(quarter))
{
groupedDates[quarter].Add(date);
}
else
{
List<DateTime> dateGroup = new List<DateTime>();
dateGroup.Add(date);
groupedDates.Add(quarter,dateGroup);
}
}
,这将按年份将其分组:
events.GroupBy(e => string.Format(\"{0}.{1}+\",e.date.DayOfYear,e.date.Year);
因此,现在您只需要找出日期的WeekOfYear或QuarterOfYear属性并将其用作分组子句即可。
对于QuarterOfYear,它可能看起来像这样:
events.GroupBy(e => string.Format(\"{0}.{1}+\",(e.date.Month % 4) + 1,e.date.Year);
但是就这一周而言,情况变得更加复杂。据我所知,有多种方法可以开始计算一年中的几周。检查NodaTime或其他日期库为您完成此操作...
,原地返回日期。
event.Sort((x,y) => DateTime.Compare(x.date,y.date));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。