自定义函数计算两个日期之间的假期数

问题描述:

客户要求计算两个日期之间的工作天数,几经周折之下想到了一个反过来计算的方法,为什么不求出两个日期之间的假期和两个日期之间的实际天数,然后来进行相减操作呢?

 

解决方法:

由于函数不包含计算假期的函数,所以得通过自定义函数实现

 

主要思路:

1写一个获得日期的下一天的函数

写一个判断日期是否周末的函数

通过两个数组(a 特殊周末数组  b 国家假期数组)来对起始日期到结束日期的循环遍历判断是否属于这两个数组

 

部分代码:

import java.text.ParseException;

import java.text.SimpleDateFormat;

import java.util.Calendar;

import java.util.Date;

 

 

public class hlDay {

      /**

      * 获得指定日期的后一天

      * @param cal

      * @return

      */

public  static String getNextDay(String cal, int i){

      Calendar c = Calendar.getInstance();

      Date date=null;

      try {

           date = new SimpleDateFormat(“yyyy/MM/dd”).parse(cal);

      } catch (ParseException e) {

      e.printStackTrace();

      }

      c.setTime(date);

      int day=c.get(Calendar.DATE);

      c.set(Calendar.DATE,day+i);

 

      String dayAfter=new SimpleDateFormat(“yyyy/MM/dd”).format(c.getTime());

      return dayAfter;

}

//判断是否是周末

public static boolean isWeekend(String cal) {

      Calendar c = Calendar.getInstance();

      Date date=null;

      try {

           date = new SimpleDateFormat(“yyyy/MM/dd”).parse(cal);

      } catch (ParseException e) {

           e.printStackTrace();

      }

      c.setTime(date);

      if(c.get(Calendar.DAY_OF_WEEK)-1 == 0 || c.get(Calendar.DAY_OF_WEEK)- 1 == 6) {

           return true;

      } else{

           return false;

      }

}

 

详细代码见附件,算法比较简单,但是对调休日期进行添加和国家假期进行添加比较麻烦,欢迎大家提出改进意见,谢谢

热门文章