如何使用 linq 或 lambda 表达式获取开始日期和结束日期之间的日期列表。
DateTime StartDate = DateTime.Now;
DateTime EndDate = DateTime.Now.AddMonths(13);
List<DateTime> ListofDates = //Contains list of all dates only between start and end date.
Enumerable.Range(0, (EndDate - StartDate).Days).Select(i => StartDate.AddDays(i))
首先,当你想要Dates
而不是Datetimes
你最好使用DateTime.Now.Date
而不是仅仅DateTime.Now
我已经编辑了 SLaks 代码,所以你可以得到你想要的日期列表。
DateTime StartDate = DateTime.Now.Date;
DateTime EndDate = DateTime.Now.Date.AddMonths(13);
IEnumerable<double> daysToAdd = Enumerable.Range(0,
(EndDate - StartDate).Days + 1)
.ToList().ConvertAll(d => (double)d);
IEnumerable<DateTime> ListOfDates = daysToAdd.Select(StartDate.AddDays).ToList();
请注意,我已+1
在可枚举中添加,因此您可以同时拥有日期start
和end
日期(您没有指定它)
List<DateTime> ListofDates = Enumerable.Range(0, (EndDate - StartDate).Days)
.Select(i => StartDate.AddDays(i))
.ToList();