1

给定一个日期,我希望计算当前的年度季度。

如果今天的日期大于给定日期,我希望根据给定日期计算当前年度季度的最后一个月,以及下一个年度季度的第一个月。

我工作的季度是 jan-mar、apr-jun、jul-sep 和 oct-dec。

如果日期输入是 2013 年 1 月 10 日,我希望输出是 1 月(下一个年度季度的第一个月)和 12 月(当前年度季度的最后一个月)。在这种情况下,月变量将包含值 10,而日变量将包含值 1。

到目前为止我的尝试:

每个季度的最后一个月

if (month % 3 == 0)
  month += (DateTime.Now.Day > day ? 3 : 0);
if (month % 3 == 1)
  month += 2;
if (month % 3 == 2)
  month += 1;

每个季度的第一个月

if (month % 3 == 1) // jan/mapr/jul/oct
  month += (DateTime.Now.Day > day ? 3 : 0);
if (month % 3 == 2) // feb/may/aug/nov
  month += 2;
if (month % 3 == 0) // mar/jun/sep/dec
  month += 1;
4

6 回答 6

5

您可以使用整数数学获得当前季度。

int currentQuarter = ((month-1)/3)+1;

这是有效的,因为整数除法总是会被截断,所以如果月份是 1 到 3,你将得到 0 到 2 超过 3,这将等于 0。月份 4 到 6 将得到 3-5 超过 3,这将等于 1,依此类推。

对于给定的季度,第一个月和最后一个月将由以下方式给出:

int firstMonthOfQuarter = (quarter*3)-2;

int lastMonthOfQuarter = (quarter*3);

请注意,quarter这些将是您想要该月的季度。如果您想要当前季度,请使用它。如果你想要下一个季度然后quarter+=1检查溢出(即如果季度是 5 那么它实际上是 1)。或者,您可以添加%12第一个月和最后一个月的计算,然后它可以在 5 的四分之一处正常工作。

int firstMonthOfQuarterOfNextQuarter = (((quarter+1)*3)-2)%12;
int lastMonthOfQuarterOfNextQuarter = ((quarter+1)*3)%12;

我对你想如何把它放在一起有点困惑,因为你要么想要当前季度(如我的第一行所示),要么在某些情况下还想要下一个季度和当前季度的第一个月和最后一个月。我不知道你是如何退货的,所以你必须自己把它放在一起。

于 2013-08-05T18:49:11.463 回答
1

如前所述,该算法提供了您想要的功能:

int quarterCurr = 1;
if (Convert.ToDouble(curMonth) / 3.0 > 1.0)
{
    quarterCurr = Convert.ToInt32(Convert.ToDouble(curMonth) / 3.0);
    if (curMonth % 3 != 0)
    {
        quarterCurr = quarterCurr + 1;
    }
}
int firstMonthCurr = 3 * (quarterCurr - 1) + 1;
int lastMonthCurr = 3 * quarterCurr;

int quarterNext = quarterCurr + 1;
if (quarterNext > 4)
{
    quarterNext = 1;
}
int firstMonthNext = 3 * (quarterNext - 1) + 1;

这是一种简单/清晰的方法来计算您需要的所有信息:每个季度的第一个月/最后一个月。

这段代码应该放在一个函数中,需要时调用。它将仅将当前月份作为输入,并作为输出返回一个长度为 2 的一维数组:当前季度最后一个月的第一个位置和下一季度第一个月的第二个位置(或任何其他选择)。因此,主要功能(计算任何输入月份的目标值)都包括在内,但您必须根据您的确切要求对其进行调整。

于 2013-08-05T18:50:05.337 回答
0

您可以使用.NET 的时间段库的Quarter类:

// ----------------------------------------------------------------------
public void QuarterStartEndMonth()
{
  DateTime now = DateTime.Now;

  Quarter pastQuarter = GetQuarter( new DateTime( now.Year - 1, 10, 1 ) );
  Console.WriteLine( "Quarter last month {0:d}", pastQuarter.LastMonthStart );
  Console.WriteLine( "Next quarter start month {0:d}",
    pastQuarter.GetNextQuarter().Start );

  Quarter futureQuarter = GetQuarter( new DateTime( now.Year + 1, 10, 1 ) );
  Console.WriteLine( "Quarter last month {0:d}", futureQuarter.LastMonthStart );
  Console.WriteLine( "Next quarter start month {0:d}",
    futureQuarter.GetNextQuarter().Start );
} // QuarterStartEndMonth

// ----------------------------------------------------------------------
private Quarter GetQuarter( DateTime moment )
{
  DateTime now = DateTime.Now;
  return new Quarter( now > moment ? now : moment );
} // GetQuarter
于 2013-08-17T10:03:24.547 回答
0
var currentDate = DateTime.Now;
var quarterNumber = ((currentDate.Month-1)/3) + 1;
var firstDayOfQuarter = new DateTime(currentDate.Year, ((quarterNumber-1) * 3) + 1, 1);
var lastDayOfQuarter = firstDayOfQuarter.AddMonths(3).AddDays(-1);
于 2013-08-05T18:49:57.210 回答
0

编写一个包装类,根据当前日期时间给出第一个月或最后一个月,并从 CurrentCulture 设置中给出月份的名称

class Program
{
    static void Main(string[] args)
    {
        Console.WriteLine(Quater.GetFirstMonth(DateTime.Now.Month)); // Outputs october
        Console.WriteLine(Quater.GetLastMonth(DateTime.Now.Month)); // Outputs september

        Console.ReadLine();
    }
}

public static class Quater
{
    public static string GetFirstMonth(int month)
    {
        if (month >= 1 && month <= 3) {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(4);
        }
        if (month >= 4 && month <= 6) {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(7);
        }
        if (month >= 7 && month <= 9) {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(10);
        }
        if (month >= 10 && month <= 12) {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(1);
        }

        return string.Empty;
    }

    public static string GetLastMonth(int month)
    {
        if (month >= 1 && month <= 3)
        {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(3);
        }
        if (month >= 4 && month <= 6)
        {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(6);
        }
        if (month >= 7 && month <= 9)
        {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(9);
        }
        if (month >= 10 && month <= 12)
        {
            return CultureInfo.CurrentCulture.DateTimeFormat.GetMonthName(12);
        }

        return string.Empty;
    }
}
于 2013-08-05T18:51:21.223 回答
0

这些辅助方法应该为您提供所需的一切:

public static class DateTimeHelpers
{
    private static DateTime StartDateOfCurrentQuarter( DateTime instant )
    {
        return new DateTime( instant.Year , 1 + 3*((instant.Month-1)/3) , 1 ) ;
    }
    public static void CurrentQuarter( this DateTime instant , out DateTime start , out DateTime end )
    {
        start = StartDateOfCurrentQuarter(instant) ;
        end   = start.AddMonths(3).AddTicks(-1) ;
        return ;
    }
    public static void NextQuarter( this DateTime instant , out DateTime start , out DateTime end )
    {
        start = StartDateOfCurrentQuarter(instant).AddMonths(3) ;
        end   = start.AddMonths(3).AddTicks(-1) ;
        return ;
    }
    public static void PrevQuarter( this DateTime instant , out DateTime start , out DateTime end )
    {
        start = StartDateOfCurrentQuarter(instant).AddMonths(-3) ;
        end   = start.AddMonths(3).AddTicks(-1) ;
        return ;
    }
}
于 2013-08-05T19:18:03.490 回答