首页 > 解决方案 > 如何从按周、月、季度或年分组的随机日期列表中提取最大日期?

问题描述

给定一个随机日期列表,是否有一种优雅的 C# 方式(LINQ 或其他方式)来提取列表中的最后一个日期,按周、月、季度或年分组?

我希望这很清楚,但如果不是,请使用此示例日期集:

按周提取最大值将产生

并按月提取最大值将产生

我需要能够按周数、日历月、日历季度和日历年进行提取。

我什至不知道如何开始。所以目前我没有代码可以分享。

任何想法都将受到欢迎。

澄清:为了我们人类的利益,此处包含工作日名称。我的实际日期是正确的DateTime类型。所以代码不需要将字符串解析为日期时间。

此外,我可以在没有 LINQ 的情况下轻松编写类似的东西。但我希望的是使用 LINQ 或其他一些巧妙技巧的优雅解决方案。

标签: c#linqdatecalendar

解决方案


这使用 LINQ 非常简单。这里是按月分组的示例:

var grouped = dates.OrderBy(x => x.Ticks).GroupBy(x => x.Month)
                   .Select(x => new {Month = x.Key, Max = x.Max()});

这为您提供了示例:

{ 月 = 1,最大值 = 2018 年 1 月 31 日上午 12:00:00 }

{ 月 = 2,最大值 = 2/27/2018 12:00:00 AM }


要在一周内执行此操作,请将此 lambda 用于GroupBy

x => CultureInfo.InvariantCulture.Calendar.GetWeekOfYear(
         x, CalendarWeekRule.FirstFourDayWeek, DayOfWeek.Monday
     )

输出:

{ 周 = 1,最大值 = 2018 年 1 月 4 日上午 12:00:00 }

{ 周 = 2,最大值 = 2018 年 1 月 12 日上午 12:00:00 }

{ 周 = 4,最大值 = 2018 年 1 月 24 日上午 12:00:00 }

{ 周 = 5,最大值 = 2/1/2018 12:00:00 AM}

{ 周 = 9,最大值 = 2/27/2018 12:00:00 AM }


季度

x => (x.Month + 2)/3

输出:

{ 季度 = 1,最大值 = 2/27/2018 12:00:00 AM}


年度:_

x => x.Year

输出

{ 年 = 2018,最大值 = 2/27/2018 12:00:00 AM }


推荐阅读