25

我想知道何时给出开始和结束日期,如何检索两个日期之间的月份和年份。

例如:Start Date: '1/1/2011'(mm/dd/yyyy)End date :'11/30/2011'。要检索的月份和年份是January,2011; February,2011; March,2011; and so on till November,2011

4

5 回答 5

57

开始了

public static IEnumerable<(string Month, int Year)> MonthsBetween(
        DateTime startDate,
        DateTime endDate)
{
    DateTime iterator;
    DateTime limit;

    if (endDate > startDate)
    {
        iterator = new DateTime(startDate.Year, startDate.Month, 1);
        limit = endDate;
    }
    else
    {
        iterator = new DateTime(endDate.Year, endDate.Month, 1);
        limit = startDate;
    }

    var dateTimeFormat = CultureInfo.CurrentCulture.DateTimeFormat;
    while (iterator <= limit)
    {
        yield return (
            dateTimeFormat.GetMonthName(iterator.Month), 
            iterator.Year
        );

       iterator = iterator.AddMonths(1);
    }
}

显然你这样称呼它

var startDate = DateTime.ParseExact("01/01/2011", "MM/dd/yyyy");
var endDate = DateTime.ParseExact("11/30/2011", "MM/dd/yyyy");

var months = MonthsBetween(startDate, endDate);

结果应该类似于

{
    {  "January", 2011  },
    {  "February", 2011  },
    {  "March", 2011  },
    {  "April", 2011  },
    {  "May", 2011  },
    {  "June", 2011  },
    {  "July", 2011  },
    {  "August", 2011  },
    {  "September", 2011  },
    {  "October", 2011  },
    {  "November", 2011  },
}

月份名称取决于您的文化,我认为这正是您所要求的,对吧?

于 2012-08-13T08:38:31.233 回答
24

您可以从开始日期小于或等于结束日期的 while 循环开始

在其中从开始日期拉出相关的月份和年份部分并存储它们(也许你有一个具体的类或 a as a ),然后使用将开始日期增加 1 个月AddMonths(1)

//something on these lines 
while(startdate <= enddate)
{
// pull out month and year
startdate = startdate.AddMonths(1);
}
于 2012-08-13T08:41:14.913 回答
7

您可以使用 Enumerable.Range 函数来获取两个日期之间的月份和年份,

var start = new DateTime(2011, 1, 1);
var end = new DateTime(2011, 11, 30);

var diff = Enumerable.Range(0, 13).Select(a => start.AddMonths(a))
           .TakeWhile(a => a <= end)
           .Select(a => String.Concat(a.ToString("MMMM") + ", " + a.Year));
于 2016-03-30T13:59:49.547 回答
4

使用这个公式:

((date1.Year - date2.Year) * 12) + date1.Month - date2.Month

你得到月数。

以适当的方式使用它,您将破解它。

欢迎来到 Stackoverflow ,在这里努力工作是你的一部分,并为此提供思考线,以便兄弟会在你遇到问题时做。

于 2012-08-13T08:30:23.920 回答
-1

您可以通过使用 Enumerable.Range(startIndex, endIndex) 来使用 Linq。
下面的例子:

    private string[] GetMonthsBetweenDates(DateTime deltaDate, int TotalMonths)
{
    var monthsBetweenDates = Enumerable.Range(0, TotalMonths)
                                       .Select(i => deltaDate.AddMonths(i))
                                       .OrderBy(e => e)
                                       .AsEnumerable();

    return monthsBetweenDates.Select(e => e.ToString("MMM")).ToArray();
}

假设当前月份是 11 月,上面的代码应该会产生以下结果。

Nov
Dec
Jan
Feb
Mar
Apr
May
Jun
Jul
Aug
Sep
Oct
于 2018-11-26T19:43:16.367 回答