[英]How to check if the current day is the Nth or Nth from last business day of the month?
我意识到有人问过类似的问题,但是我觉得这个问题有不同的要求。
我需要检查当前日期是该月的最后一个工作日的第N个还是第N个。 如果是,我将启动另一个任务,否则我将退出。
就像是 :
void doTask()
{
if (NthFirstOrNthLastBusinessDay())
{ // do stuff }
else
{ // do nothing }
}
bool NthFirstOrNthLastBusinessDay()
{}
到目前为止,我想我可以按照此处的答案来获取当月的最后一个工作日(以及类似地每月的第一个工作日),然后应用一堆条件来计算从该日期起的第N个工作日。
有没有更好的办法?
例如,如果N为4,则仅当今天是该月的第4个工作日或该月的最后一个工作日的第4个工作日时,才应运行我的任务。
本质上,我每天都调用此方法,它检查当天是否满足此条件,如果满足,则运行该任务,否则不执行。
因此,我的任务应在2014年7月28日和2014年8月6日,然后在2014年8月26日运行,依此类推。
编辑:这是我在N = 4的情况下编写的一些代码:
/// <summary>
/// Checks if the current day is the 4th business day or the 4th last business day of the month
/// </summary>
/// <returns> True if current day satisfies condition, false otherwise </returns>
private bool NthFirstOrNthLastBusinessDay()
{
return (IsFourthBusinessDay() || IsFourthFromLastBusinessDay());
}
/// <summary>
/// Checks if today is the fourth business day of the month
/// </summary>
/// <returns> True if today satisfies condition, else false </returns>
private bool IsFourthBusinessDay()
{
var dateToday = DateTime.Today;
var firstDayOfThisMonth = new DateTime(dateToday.Year, dateToday.Month, 1);
switch (firstDayOfThisMonth.DayOfWeek)
{
case DayOfWeek.Sunday:
firstDayOfThisMonth = firstDayOfThisMonth.AddDays(4);
break;
case DayOfWeek.Monday:
firstDayOfThisMonth = firstDayOfThisMonth.AddDays(3);
break;
case DayOfWeek.Tuesday:
firstDayOfThisMonth = firstDayOfThisMonth.AddDays(3);
break;
default:
firstDayOfThisMonth = firstDayOfThisMonth.AddDays(5);
break;
} // firstDayOfMonth now contains first business day of month
return dateToday == firstDayOfThisMonth;
}
/// <summary>
/// Checks if today is the fourth from last business day of the month
/// </summary>
/// <returns> True if today satisfies condition, else false </returns>
private bool IsFourthFromLastBusinessDay()
{
var dateToday = DateTime.Today;
var lastDayOfThisMonth = new DateTime(dateToday.Year, dateToday.Month, DateTime.DaysInMonth(dateToday.Year, dateToday.Month));
switch (lastDayOfThisMonth.DayOfWeek)
{
case DayOfWeek.Saturday:
lastDayOfThisMonth = lastDayOfThisMonth.AddDays(-4);
break;
case DayOfWeek.Friday:
lastDayOfThisMonth = lastDayOfThisMonth.AddDays(-3);
break;
case DayOfWeek.Thursday:
lastDayOfThisMonth = lastDayOfThisMonth.AddDays(-3);
break;
default:
lastDayOfThisMonth = lastDayOfThisMonth.AddDays(-5);
break;
} // firstDayOfMonth now contains first business day of month
return dateToday == lastDayOfThisMonth;
}
现在,我需要调整常规N的值。是否有更好的方法?
根据对原始答案的OP注释,我决定编写另一个函数作为练习。
这是(再次-未完全测试):
// Nth day should not be larger than 14 - I have tested it
bool Nth_BusinessDay(int NthDay, DateTime current)
{
// check we have NthDay larger than ZERO
if (NthDay < 1)
return false;
// make sure the taget date is just a date - no time component
DateTime target = current.Date;
// make sure the specialDay is not larger than the current days in the month
if (DateTime.DaysInMonth(target.Year, target.Month) > NthDay)
return false;
// start at the beginning
DateTime NthStart = new DateTime(target.Year, target.Month, 1);
// check if start date falls on the weekend
if (NthStart.DayOfWeek == DayOfWeek.Saturday)
NthStart = NthStart.AddDays(2); // jump TWO days to Monday
if (NthStart.DayOfWeek == DayOfWeek.Sunday)
NthStart = NthStart.AddDays(1); // jump ONE day to Monday
// now add our Nth day
NthStart = NthStart.AddDays(NthDay - 1);
// if we land on weekend after we adjusted for the Nth - push it by two days
if (NthStart.DayOfWeek == DayOfWeek.Saturday || NthStart.DayOfWeek == DayOfWeek.Sunday)
NthStart = NthStart.AddDays(2);
// start at the end and minus the Nth day
DateTime NthEnd = new DateTime(target.Year, target.Month, DateTime.DaysInMonth(target.Year, target.Month));
// check if the end date falls on the weekend - the difference here is the adjustment
if (NthEnd.DayOfWeek == DayOfWeek.Saturday)
NthEnd = NthEnd.AddDays(-1); // jump ONE day back to Friday
if (NthEnd.DayOfWeek == DayOfWeek.Sunday)
NthEnd = NthEnd.AddDays(-2); // jump TWO days back to Friday
// now subject our Nth day from the End
NthEnd = NthEnd.AddDays((NthDay - 1) * -1);
// again if we land on weekend - adjust by two days
if (NthStart.DayOfWeek == DayOfWeek.Saturday || NthStart.DayOfWeek == DayOfWeek.Sunday)
NthStart = NthStart.AddDays(2);
// check if our target day is one of the Nth day
if (NthStart == target || NthEnd == target)
return true;
return false;
}
并使用上面的功能:
void doTaskNthDay()
{
if (Nth_BusinessDay(5, DateTime.Now))
{
// do stuff
}
}
以下是我留给我的原始答案,仅供参考。
我从以下代码中获取了代码: .NET日期比较:计算自日期以来的工作日数? 。 我尚未测试此代码,但您可以尝试执行以下操作:
int BuinessDayCount(DateTime targetDay)
{
// check if the target day is a weekend
if (targetDay.DayOfWeek == DayOfWeek.Saturday)
return -1;
if (targetDay.DayOfWeek == DayOfWeek.Sunday)
return -2;
// get the start of the month
DateTime start = new DateTime(targetDay.Year, targetDay.Month, 1);
// create a target without any time component
DateTime end = targetDay.Date;
int workingDays = 0;
while (start <= targetDay)
{
if (start.DayOfWeek != DayOfWeek.Saturday
&& start.DayOfWeek != DayOfWeek.Sunday)
{
workingDays++;
}
start = start.AddDays(1);
}
return workingDays;
}
然后在您的代码中,我将执行以下操作:
void doTask()
{
int businessDay = BuinessDayCount(DateTime.Now);
if (businessDay == 5 || businessDay == 25)
{
// do stuff
}
}
我认为它会读得更好。
我会做类似的事情:
int numOfOccurredBusinessDays = 0; // this will include current business day
int businessDaysLeft = 0;
var currentDate = DateTime.Now;
var monthIterator = new DateTime(DateTime.Year, DateTime.Month, 1);
for (int i = 0; i < DateTime.DaysInMonth; ++i, monthIterator.AddDay(1))
{
if (monthIterator <= currentDate &&
!monthIterator.Date.ToString("D").Contains("Sat") &&
!monthIterator.Date.ToString("D").Contains("Sun"))
numOfOccurredBusinessDays++;
else if (monthIterator > currentDate &&
!monthIterator.Date.ToString("D").Contains("Sat") &&
!monthIterator.Date.ToString("D").Contains("Sun"))
businessDaysLeft++;
}
创建一个新的System.DateTime对象。 用当年和当月(可从DateTime.Now获取)初始化它。 如果是9月/ 4月/ 6月/ 11月,则将日期设置为30,或31、28等。
现在,您有一个DateTime对象,表示每月的最后一天。 您可以使用DateTime.DayOfWeek检查日期是星期六还是星期天(或节假日)。
您可以使用DateTime.AddDays(-N)在第一天“回退” DateTime对象,然后再次检查它是星期六还是星期天(或节假日)。
对每月需要进行的第N次检查重复一次。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.