检索Linq给定范围内的特定星期几?

时间:2012-07-24 13:56:01

标签: c#

是否可以给出一个日期范围来提取一周中的特定日期并显示其日期?

所以,如果我的日期范围是从2012年8月17日到2012年9月17日,那么有可能使用linq来说出所有周四和周二吗?

2 个答案:

答案 0 :(得分:8)

您可以确定日期之间的天数,然后生成所有日期并过滤您感兴趣的一周中的日期。

var start = DateTime.Parse("08/17/2012");
var end = DateTime.Parse("09/17/2012");
int numberOfDays = end.Subtract(start).Days + 1;
var daysOfWeek = new[] { DayOfWeek.Tuesday, DayOfWeek.Thursday };

var dates = Enumerable.Range(0, numberOfDays)
                      .Select(i => start.AddDays(i))
                      .Where(d => daysOfWeek.Contains(d.DayOfWeek));

答案 1 :(得分:4)

var start = new DateTime(2012, 8, 17);
var end = new DateTime(2012, 9, 17);

var daysToChoose = new DayOfWeek[] { DayOfWeek.Thursday, DayOfWeek.Tuesday };

var dates = Enumerable.Range(0, (int)(end - start).TotalDays + 1)
                        .Select(d => start.AddDays(d))
                        .Where(d => daysToChoose.Contains(d.DayOfWeek));