如何计算java中任何月份的工作日数?
如何计算java中任何月份的工作日数?我的输入是以整数表示的月份。 例如,要获得9月份的工作日数,我的输入是9。如何计算java中任何月份的工作日数?,java,Java,如何计算java中任何月份的工作日数?我的输入是以整数表示的月份。 例如,要获得9月份的工作日数,我的输入是9。 我没有开始或结束日期。周末是周六和周日。请帮助。这种方法可能不是最理想的,但至少可以避免任何循环。我试着逐字逐句地解决它,所以这里是总体思路,希望它适合你: static int countHolidays(int month){ //assuming month is 1-12 Calendar firstDayCal = Calendar.getInstance(
我没有开始或结束日期。周末是周六和周日。请帮助。这种方法可能不是最理想的,但至少可以避免任何循环。我试着逐字逐句地解决它,所以这里是总体思路,希望它适合你:
static int countHolidays(int month){
//assuming month is 1-12
Calendar firstDayCal = Calendar.getInstance();
Calendar lastDayCal = Calendar.getInstance();
firstDayCal.set(Calendar.MONTH, month-1);//here we should put 0-11;
lastDayCal.set(Calendar.MONTH, month-1);
int firstDay = firstDayCal.getActualMinimum(Calendar.DAY_OF_MONTH);
int lastDay = firstDayCal.getActualMaximum(Calendar.DAY_OF_MONTH);
firstDayCal.set(Calendar.DAY_OF_MONTH, firstDay);
lastDayCal.set(Calendar.DAY_OF_MONTH, lastDay);
//any month have no less than 28 days, so 4 full weeks - so 8 weekends.
int total = 8;
switch (lastDay) {
case 29:
//leap-year february can have one extra holiday if it starts on sunday or ends on saturday
if ((firstDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SUNDAY) || (lastDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SATURDAY)){
total++;
} break;
case 30:
//30-day month can have one extra holiday if it starts on sunday or ends on saturday...
if ((firstDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SUNDAY) || (lastDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SATURDAY)){
total++;
//...or two extra holiday if it starts on saturday or ends on sunday
} else if ((firstDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SATURDAY) || (lastDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SUNDAY)){
total = total + 2;
} break;
case 31:
//31-day month can have one extra holiday if it starts on sunday or ends on saturday...
if ((firstDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SUNDAY) || (lastDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SATURDAY)){
total++;
//...or two extra holiday if it starts on (friday or saturday) or ends on (sunday or monday)
} else if (((firstDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.FRIDAY) || (firstDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SATURDAY)) ||
((lastDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.SUNDAY) || (lastDayCal.get(Calendar.DAY_OF_WEEK) == Calendar.MONDAY))) {
total = total + 2;
} break;
default:
break;
}
return lastDay-total;//as we need workingDays, not weekends
}
请提供您的代码以获取准确的数据,您还需要输入
年份
您必须考虑到国家假日吗?您唯一输入的是整数
形式的月份,这意味着您只对当前年份感兴趣,对吗?请参阅