`
gaowenming
  • 浏览: 166707 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

java获取2个日期之间的工作日天数(转)

阅读更多
对于任意2个日期比如:date_start=2006-10-1、date_end=2006-10-14 ,首先计算这连个日期之间的时间间隔(天数),然后分别对date_start 和date_end 取得它们下一个星期一的日期,这样就可以得到一个新的可以整除7的完整日期间隔(这个新的日期间隔已经把星期几的问题剔出掉了),换一种说法就是我们可以得到,这两个新的日期之间的周数,拿这个周数乘以5就是工作日期了(tmpWorkingDays)。但是这个日期并不是我们所要的日期,接下来我们要做的就是计算date_start,date_end这两个日期对于根据它们所产生的新的日期之间的时间偏移量,date_start的偏移量(date_start_change)是需要加的,而date_end的这个偏移量(date_end_change)是需要减去的。 最后我们只要用tmpWorkingDays+date_start_change-date_end_change就是我们所要求的实际工作日了。以下是所有实现代码(两个日期跨年也没有问题)。    
  
  
主要思路:   
  
对于任意2个日期比如:date_start=2006-10-1、date_end=2006-10-14 ,首先计算这连个日期之间的时间间隔(天数),然后分别对date_start 和date_end 取得它们下一个星期一的日期,这样就可以得到一个新的可以整除7的完整日期间隔(这个新的日期间隔已经把星期几的问题剔出掉了),换一种说法就是我们可以得到,这两个新的日期之间的周数,拿这个周数乘以5就是工作日期了(tmpWorkingDays)。但是这个日期并不是我们所要的日期,接下来我们要做的就是计算date_start,date_end这两个日期对于根据它们所产生的新的日期之间的时间偏移量,date_start的偏移量(date_start_change)是需要加的,而date_end的这个偏移量(date_end_change)是需要减去的。 最后我们只要用tmpWorkingDays+date_start_change-date_end_change就是我们所要求的实际工作日了。以下是所有实现代码(两个日期跨年也没有问题)。   
  
希望我的方法能对大家有用,应为这个算法没有考虑到节假日的问题,我以后会像办法处理,呵呵,今天就到这里了。   
  
package com.date.utlit;   
  
import java.text.SimpleDateFormat;   
import java.util.Calendar;   
import java.util.Date;   
import java.util.GregorianCalendar;   
/**  
 * 计算任意2个日期内的工作日(没有考虑到国定假日)  
 * @author user  
 *  
 */  
public class DateCal {   
  
 /**  
  * @param args  
  */  
 public static void main(String[] args) {   
  try {   
  
   String strDateStart = "2006-10-1";   
   String strDateEnd = "2006-10-14";   
   SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");   
   Date date_start = sdf.parse(strDateStart);   
   Date date_end = sdf.parse(strDateEnd);   
   DateCal app = new DateCal();   
   Calendar cal_start = Calendar.getInstance();   
   Calendar cal_end = Calendar.getInstance();   
   cal_start.setTime(date_start);   
   cal_end.setTime(date_end);   
   System.out.println("星期-->" + app.getChineseWeek(cal_start)   
     + " 日期-->" + cal_start.get(Calendar.YEAR) + "-"  
     + (cal_start.get(Calendar.MONTH) + 1) + "-"  
     + cal_start.get(Calendar.DAY_OF_MONTH));   
   System.out.println("星期-->" + app.getChineseWeek(cal_end) + " 日期-->"  
     + cal_end.get(Calendar.YEAR) + "-"  
     + (cal_end.get(Calendar.MONTH) + 1) + "-"  
     + cal_end.get(Calendar.DAY_OF_MONTH));   
   System.out.println("工作日为-->"  
     + app.getWorkingDay(cal_start, cal_end));   
   System.out.println("休息日-->"+app.getHolidays(cal_start, cal_end));   
  } catch (Exception e) {   
   // TODO: handle exception   
  }   
 }   
  
 public int getDaysBetween(java.util.Calendar d1, java.util.Calendar d2) {   
  if (d1.after(d2)) { // swap dates so that d1 is start and d2 is end   
   java.util.Calendar swap = d1;   
   d1 = d2;   
   d2 = swap;   
  }   
  int days = d2.get(java.util.Calendar.DAY_OF_YEAR)   
    - d1.get(java.util.Calendar.DAY_OF_YEAR);   
  int y2 = d2.get(java.util.Calendar.YEAR);   
  if (d1.get(java.util.Calendar.YEAR) != y2) {   
   d1 = (java.util.Calendar) d1.clone();   
   do {   
    days += d1.getActualMaximum(java.util.Calendar.DAY_OF_YEAR);   
    d1.add(java.util.Calendar.YEAR, 1);   
   } while (d1.get(java.util.Calendar.YEAR) != y2);   
  }   
  return days;   
 }   
  
 /**  
  * 计算2个日期之间的相隔天数  
  * @param d1  
  * @param d2  
  * @return  
  */  
 public int getWorkingDay(java.util.Calendar d1, java.util.Calendar d2) {   
  int result = -1;   
  if (d1.after(d2)) { // swap dates so that d1 is start and d2 is end   
   java.util.Calendar swap = d1;   
   d1 = d2;   
   d2 = swap;   
  }   
  
  int betweendays = getDaysBetween(d1, d2);   
  
     
  int charge_date = 0;   
  int charge_start_date = 0;//开始日期的日期偏移量   
  int charge_end_date = 0;//结束日期的日期偏移量   
   // 日期不在同一个日期内   
   int stmp;   
   int etmp;   
   stmp = 7 - d1.get(Calendar.DAY_OF_WEEK);   
   etmp = 7 - d2.get(Calendar.DAY_OF_WEEK);   
   if (stmp != 0 && stmp != 6) {// 开始日期为星期六和星期日时偏移量为0   
    charge_start_date = stmp - 1;   
   }   
   if (etmp != 0 && etmp != 6) {// 结束日期为星期六和星期日时偏移量为0   
    charge_end_date = etmp - 1;   
   }   
//  }   
  result = (getDaysBetween(this.getNextMonday(d1), this.getNextMonday(d2)) / 7)   
    * 5 + charge_start_date - charge_end_date;   
  //System.out.println("charge_start_date>" + charge_start_date);   
  //System.out.println("charge_end_date>" + charge_end_date);   
  //System.out.println("between day is-->" + betweendays);   
  return result;   
 }   
  
 public String getChineseWeek(Calendar date) {   
  final String dayNames[] = { "星期日", "星期一", "星期二", "星期三", "星期四", "星期五",   
    "星期六" };   
  
  int dayOfWeek = date.get(Calendar.DAY_OF_WEEK);   
  
  // System.out.println(dayNames[dayOfWeek - 1]);   
  return dayNames[dayOfWeek - 1];   
  
 }   
  
 /**  
  * 获得日期的下一个星期一的日期  
  *   
  * @param date  
  * @return  
  */  
 public Calendar getNextMonday(Calendar date) {   
  Calendar result = null;   
  result = date;   
  do {   
   result = (Calendar) result.clone();   
   result.add(Calendar.DATE, 1);   
  } while (result.get(Calendar.DAY_OF_WEEK) != 2);   
  return result;   
 }    
    
 /**  
  *   
  * @param d1  
  * @param d2  
  * @return  
  */  
 public int getHolidays(Calendar d1,Calendar d2){   
  return this.getDaysBetween(d1, d2)-this.getWorkingDay(d1, d2);   
     
 }   
  
}   
 

 

分享到:
评论

相关推荐

    java中计算某个月的工作日总共几天

    在Java中,要计算一个月内有多少个工作日(通常指周一至周五),以及具体哪些日子是工作日,可以通过多种方法实现。这里将介绍一种较为通用的方法:利用`java.util.Calendar`类来计算指定月份内的工作日。 #### 一...

    java获取当年的法定节假日和工作日等信息

    获取当年中国的法定节假日和工作日等信息。 如下是当前包含的功能: * 01-给定日期,判断是否是休息日(包含法定节假日... * 2、判断日期是否为工作日 * if(cc.isWorkday()){ * //工作日,在这里做你想做的事情 * }

    计算2个日期相差天数、去除节假日周末

    该函数会调用`daysBetween`获取总天数,然后遍历每个日期,排除周末和节假日,统计有效工作日。 整个过程大致如下: 1. 计算两个日期之间的总天数。 2. 遍历这个天数范围内的每一天,检查是否为工作日。 3. 如果是...

    计算除周六日、法定节假日以外两个日期之间的间隔天数

    计算除周六日、法定节假日以外两个日期之间的间隔天数

    java得到下一个法定工作日期

    在Java编程中,获取下一个法定工作日期是一项常见的需求,特别是在处理日期相关的业务逻辑时,例如请假天数计算、工资结算等。这篇博文“java得到下一个法定工作日期”可能讲述了一个实用的方法来解决这个问题。通常...

    2023年日历(标记工作日,节假日,调休,周末),计算两个日期相差的工作日天数

    压缩包里有2个文件,用于计算两个日期相差的工作日天数(排除周末和法定节假日): 1、excel表为2023年日历数据,并且备注工作日、周末,调休、节假日类型,可导入数据库。 2、SQL文件为2023年所有日期的插入SQL,并...

    JAVA时间工具类(计算法定工作日工时等)

    JAVA时间工具类(计算法定工作日工时):计算某个日期加上几个工作日后的一个工作日期(除周末和法定节假日),计算某个日期后一天的工作日期(除周末和法定节假日),计算两个日期的真实工作日(除周末和法定节假日),...

    java 请假天数计算工具类

    使用Java 8的日期时间API(`java.time`包)来处理日期和时间,如计算两个日期之间的天数,判断是否为工作日等。同时,为了提高效率和减少数据库交互,可以利用Redis的特性,将部分计算结果缓存起来。 综上所述,这...

    java计算整年工作日(包含特殊的工作日)排除法定节假日和周末能运行

    java计算整年工作日(包含特殊的工作日)排除法定节假日和周末能运行

    Java 实现将每年的节假日,周末,工作日详情记录至数据库表中

    这个类可能包含了连接数据库、获取日期信息、判断工作日/周末/节假日、批量插入数据等方法。 8. **测试与优化**: 为了确保程序的正确性,需要编写单元测试,覆盖所有可能的边界情况,如闰年、非工作日的节假日等。...

    Java节假日算法(免费)

    在这个方法中,我们使用了 Calendar 的 getDayOfWeek() 方法来获取每个日期的星期几,然后检查是否是周末,如果是,则减去相应的天数。这样可以避免假期和周末的重叠情况。 在这个算法中,我们还使用了 List 和 ...

    使用Java的Calendar类计算两段时间之间的工作日的天/小时/分钟/秒数

    该工具类用于两个时间段之间节假日的计算(可获取两个时间段之间的节假日天数,小时,分钟,秒)

    java计算全年周日 及过滤法定节假日

    java代码先获取全年的周末周日,定义全年的法定节假日,然后根据输入的日期计算,当前日期后的工作日,也可以用于计算工作日

    SQL工作日计算,只排除周末

    在数据库管理和数据分析领域,准确地计算两个日期之间的有效工作日数量是一项非常实用的功能,特别是在需要排除周末(通常指周六和周日)的情况下。这种计算方法对于财务报告、项目管理以及人力资源规划等方面至关...

    根据日期获取最近几天的日期

    本文将深入探讨如何根据一个给定的日期获取最近几天的日期,主要涉及Java中的`Calendar`类,这是一个强大的日期和时间管理工具。 `Calendar`类是Java中的一个抽象类,它提供了对日期和时间的完整操作。要根据给定的...

    java如何获取两个日期的时间差

    "Java获取两个日期的时间差" Java获取两个日期的时间差是Java开发中常见的需求,以下是对该问题的详细解释和解决方案。 获取两个日期的时间差 要获取两个日期的时间差,我们需要使用Java中的日期和时间相关类,...

    java 日期帮助类

    - `daysBetween(Date date1, Date date2)`:计算两个日期之间的天数差。 - `monthsBetween(Date date1, Date date2)`:计算两个日期之间的月数差。 - `yearsBetween(Date date1, Date date2)`:计算两个日期之间...

    Java - DateUtil 日期时间转换工具类

    获取某天之后的下一个工作日;日期转毫秒数;将时间新增或减少对应日期等等。 资源功能:项目需要编写与时间转换相关的代码,使用该工具类可以简化开发。 适用人群:具有一定编程经验,能够看懂相关Date类,...

    LocalDate类获取日期和改变日期

    - `with(TemporalAdjuster adjuster)`使用调整器改变日期,如设置为下一个工作日。 5. **日期的格式化与解析** - 使用`DateTimeFormatter`类进行日期格式化,如`"yyyy-MM-dd"`。 - `format(DateTimeFormatter ...

    请假时长计算和每月工作天数计算源码

    可以先将两个日期转换为`LocalDateTime`,然后使用`Duration.between()`计算差值,最后通过`Duration.toHours()`获取小时数。 ```java import java.time.*; public class LeaveDurationCalculator { public ...

Global site tag (gtag.js) - Google Analytics