c# - 如何从按周、月、季度或年分组的随机日期列表中提取最大日期?
问题描述
给定一个随机日期列表,是否有一种优雅的 C# 方式(LINQ 或其他方式)来提取列表中的最后一个日期,按周、月、季度或年分组?
我希望这很清楚,但如果不是,请使用此示例日期集:
- 周一 01/01/2018
- 2018 年 2 月 1 日星期二
- 2018 年 4 月 1 日星期四
- 2018 年 9 月 1 日星期二
- 2018 年 11 月 1 日星期四
- 2018 年 12 月 1 日星期五
- 周一 22/01/2018
- 2018 年 1 月 23 日星期二
- 2018 年 1 月 24 日星期三
- 2018 年 1 月 31 日星期三
- 2018 年 1 月 2 日星期四
- 2018 年 2 月 27 日星期二
按周提取最大值将产生
- Thu 04/01/2018 = 样本中第一周的最后一个日期
- Fri 12/01/2018 = 样本中第二周的最后一个日期
- 2018 年 1 月 24 日星期三 = 等等。
- 2018 年 1 月 2 日星期四
- 2018 年 2 月 27 日星期二
并按月提取最大值将产生
- 2018 年 1 月 31 日星期三 = 样本中 1 月的最后一个日期
- 2018 年 2 月 27 日星期二 = 样本中 2 月的最后一个日期
我需要能够按周数、日历月、日历季度和日历年进行提取。
我什至不知道如何开始。所以目前我没有代码可以分享。
任何想法都将受到欢迎。
澄清:为了我们人类的利益,此处包含工作日名称。我的实际日期是正确的DateTime
类型。所以代码不需要将字符串解析为日期时间。
此外,我可以在没有 LINQ 的情况下轻松编写类似的东西。但我希望的是使用 LINQ 或其他一些巧妙技巧的优雅解决方案。
解决方案
这使用 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 }
推荐阅读
- python - 使用beautifulsoup按行名刮取表格元素
- java - 如何在基于 Maven 的 Java Web 应用程序中使用 Favicon?
- reactjs - ReactJS:setState 无法在 Syncfusion React Toast 中工作
- java - 为什么我的 GUI 不工作,我需要一个可见的代码吗?
- android - Android:在自定义视图中获取父布局宽度以设置子宽度
- javascript - HTML Navbar 在幻灯片下(不在屏幕上)
- c++ - strncat 对特定数字的未定义行为
- python-3.x - 安装 Jupyter 扩展,无法启用“nbextension”
- mysql - #1071 - 指定的密钥太长;phpmyadmin 中的最大密钥长度为 1000 字节错误
- python - pymc3: 示例错误: BrokenPipeError: [Errno 32] Broken pipe