20

我一直在尝试编写这个循环,但它变得越来越复杂。基本上我想取一个给定的日期并每个月循环,直到我到达当前月份。所以如果开始日期是 11/1/2011 那么我想循环

11/2011、12/2011、1/2012、2/2012 等

这是我开始的,但这不起作用。一旦我进入新的一年,我需要内部循环从 1 而不是 startdate.Month 重新开始。一般来说,有没有更好的方法来循环数月和数年?谢谢

        for (var y = startdate.Year; y <= DateTime.Now.Year; y++)
        {
            for (var m = startdate.Month; m <= 12; m++)
            {
                  //do something with m and y
            }
        }
4

6 回答 6

35
Date target = new Date(2011, 4, 1);
while (target < Date.Today) {
  // do something with target.Month and target.Year
  target = target.AddMonths(1);
}
于 2013-11-07T02:58:32.797 回答
12
DateTime endDate = DateTime.Today;
for (DateTime dt = startDate; dt <= endDate; dt = dt.AddMonths(1))
{
    Console.WriteLine("{0:M/yyyy}", dt);
}

但如果你更喜欢 while 循环,那就投票给 Dan-o。我做到了。:)

于 2013-11-07T03:22:43.023 回答
4

Sam 的回答很好,但最终不正确(如果您的开始日是 20 日,结束日是 10 日,则不包括上个月)。这是一个有效的版本:

    public void GetMonths(DateTime startTime, DateTime endTime)
    {
        var dateCounter = new DateTime(startTime.Year, startTime.Month, 1);
        var endDateTarget = new DateTime(endTime.Year, endTime.Month, 1);

        while (dateCounter <= endDateTarget)
        {
            Console.WriteLine($"The year and month is: {dateCounter.Year}, {dateCounter.Month}");
            dateCounter = dateCounter.AddMonths(1);
        }
    }
于 2018-06-26T14:11:19.183 回答
1

这将在几个月内循环,一个月中的一天不会有问题。

var date = startDate;
var endDate = DateTime.Now;

while(date.Year < endDate.Year || (date.Year == endDate.Year && date.Month <= endDate.Month))
{
    Console.WriteLine($"{date.Month}/{date.Year}");
    date = date.AddMonths(1);
}
于 2017-10-04T12:52:17.907 回答
1

在给定日期之间生成一个月的第一天的范围(如 IEnumerable`DateTime):

from range in new[] {
    new {
        start = new DateTime(2017, 6, 23),
        end = new DateTime(2018, 09, 11)
    }
}
select (
    from y in Enumerable.Range(
        range.start.Year, range.end.Year - 
        range.start.Year + 1
    )
    let ms = y == range.start.Year ? range.start.Month : 1
    let me = y == range.end.Year ? range.end.Month : 12
    select 
        from m in Enumerable.Range(ms, me - ms + 1)
        select new DateTime(y, m, 1)
).SelectMany(y => y)
于 2017-09-11T10:00:46.610 回答
0
while (startDate <= DateTime.Now)
            {
                //here you will get every new month in  year
                Console.WriteLine(startDate.Month);
                //Add Month
                startDate=startDate.AddMonths(1);
            }
于 2013-11-07T03:06:27.610 回答