Java如何计算两个时间段内的工作日天数

目录
  • 计算两个时间段内的工作日天数
    • 这种有两种方式可以解决
    • 实现的大概原理就是
  • 计算两个日期之间的周末天数

计算两个时间段内的工作日天数

一般在OA系统中都会遇到计算员工这段时间内的工作天数。

这种有两种方式可以解决

  • 一是调用第三方服务接口进行计算
  • 二是自己在系统中写代码计算

一的好处就是每年的节假日不用自己去维护直接用两个时间段就可以计算出来。但缺点是有些公司可以会和法定节假日期不一样那么这时候就计算不了了,还有就是一般这种OA的系统自己内部使用的话可能会部署在内网上那么就访问不了第三方接口了。

二需要自己维护节假日和计算。但有效的解决了方式一的缺陷;

根据方式二的特点介绍一个工具类,用来计算两个时间段内的工作天数:

import java.text.ParseException;
import java.util.*;
import org.apache.commons.lang3.time.DateFormatUtils;
import org.apache.commons.lang3.time.DateUtils;
public class CalcWorkDays {
    /**
     * 法定节假日列表
     *
     * @return
     */
    public static List<String> getHolidayList() {
        List<String> holidays = new ArrayList<>();
        // 元旦
        holidays.add("2021-01-01");
        holidays.add("2021-01-02");
        holidays.add("2021-01-03");
        // 春节
        holidays.add("2021-02-11");
        holidays.add("2021-02-12");
        holidays.add("2021-02-13");
        holidays.add("2021-02-14");
        holidays.add("2021-02-15");
        holidays.add("2021-02-16");
        holidays.add("2021-02-17");
        // 清明节
        holidays.add("2021-04-03");
        holidays.add("2021-04-04");
        holidays.add("2021-04-05");
        // 劳动节
        holidays.add("2021-05-01");
        holidays.add("2021-05-02");
        holidays.add("2021-05-03");
        holidays.add("2021-05-04");
        holidays.add("2021-05-05");
        // 端午节
        holidays.add("2021-06-12");
        holidays.add("2021-06-13");
        holidays.add("2021-06-14");
        // 中秋节
        holidays.add("2021-09-19");
        holidays.add("2021-09-20");
        holidays.add("2021-09-21");
        // 国庆节
        holidays.add("2021-10-01");
        holidays.add("2021-10-02");
        holidays.add("2021-10-03");
        holidays.add("2021-10-04");
        holidays.add("2021-10-05");
        holidays.add("2021-10-06");
        holidays.add("2021-10-07");
        return holidays;
    }
    /**
     * 需要上班的周末列表
     *
     * @return
     */
    public static List<String> getNeedWorkWeekends() {
        List<String> workWeekends = new ArrayList<>();
        workWeekends.add("2021-02-07");
        workWeekends.add("2021-02-20");
        workWeekends.add("2021-04-25");
        workWeekends.add("2021-05-08");
        workWeekends.add("2021-09-18");
        workWeekends.add("2021-09-26");
        workWeekends.add("2021-10-09");
        return workWeekends;
    }
    /**
     * 计算两个日期之间的工作日天数,包含起始日期,包含终止日期
     *
     * @param start  计算开始时间  必须传yyyy-MM-dd的格式
     * @param stop	计算结束时间  必须传yyyy-MM-dd的格式
     * @return
     * @throws ParseException
     */
    public static int calc(String start, String stop) throws ParseException {
    	//获取今年的法定节假日期
        List<String> workWeekends = getNeedWorkWeekends();
        //获取今年需要补班的日期
        List<String> holidays = getHolidayList();

        String pattern = "yyyy-MM-dd";
        Date begin = DateUtils.parseDate(start, pattern);
        Date endTime = DateUtils.parseDate(stop, pattern);
        Calendar cEnd = new GregorianCalendar();
        cEnd.setTime(endTime);
        // 计算时算入stop当天
        cEnd.add(Calendar.DATE,1);
        Date end=cEnd.getTime();
        //
        Calendar c = Calendar.getInstance();
        c.setTime(begin);
        int count = 0;
        String ymd = null;
        while (c.getTime().before(end)) {
            ymd = DateFormatUtils.format(c.getTime(), pattern);
            // 不是法定节假日
            if (!holidays.contains(ymd)) {
                // 不是休息日
                if (workWeekends.contains(ymd)) {
                    count++;
                } else {
                    // 非周末
                    if (c.get(Calendar.DAY_OF_WEEK) != 1 && c.get(Calendar.DAY_OF_WEEK) != 7) {
                        count++;
                    }
                }
            }
            c.add(Calendar.DATE, 1);
        }
        return count;
    }
}

实现的大概原理就是

循环将该时间段的法定节假日排除 加上需要补班的日期得出最后该时间段间总共有多少个需要工作的天数。

以上两部分的日期可维护在数据库中,现测试方法目前放到代码中了。

可以根据公司的制度进行调整需要工作的日期,比如在正常的工作日是休息可将该日期加到法定节假日中,在正常的休息日工作的话可将该日期添加到补班日期中。

计算两个日期之间的周末天数

import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;

/**
 * 计算两个日期之间的周末天数
 * @author yan
 *
 */
public class WeekEnd {
	public static void main(String[] args) throws ParseException {
		  // 设置传入的时间格式
	      SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
	      // 指定一个日期
	      Date date1 = dateFormat.parse("2016-11-12 13:24:16");
	      Date date2 = dateFormat.parse("2016-11-20 13:24:16");
	     //第三个三处代表是否 去除 双休日
	      System.out.println(computeHolidays(date2,date1));
	}

	public static int computeHolidays(Date t1,Date t2) throws ParseException{
		//初始化第一个日期
		Calendar cal1 = Calendar.getInstance();
		//初始化第二个日期,这里的天数可以随便的设置
		Calendar cal2 = Calendar.getInstance(); 

		// 设置传入的时间格式
		SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
		// 指定一个日期
		Date date1 = dateFormat.parse(dateFormat.format(t1));
		Date date2 = dateFormat.parse(dateFormat.format(t2));
		// 对 calendar 设置为 date 所定的日期
		cal1.setTime(date1);
		cal2.setTime(date2);

		int holidays = 0;
		//确定一个 大日期
		if(cal1.compareTo(cal2) > 0){
			Calendar temp = cal1;
			cal1 = cal2;
			cal2 = temp;
			temp = null;
		}
		while(cal1.compareTo(cal2)<=0){
			if(cal1.get(Calendar.DAY_OF_WEEK)==1||cal1.get(Calendar.DAY_OF_WEEK)==7){
				holidays++;
				System.out.println("周末:"+new SimpleDateFormat("yyyy-MM-dd").format(cal1.getTime()));
			}
			cal1.add(Calendar.DAY_OF_YEAR,1);

		}
		return holidays;
	}
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • Java计算两个日期时间之间的天数最简方法

    有一种low的方式,就是你把两个时间都换成秒,然后除以一天的秒数,然后向上取整,就是算的天数.但是这么实现太low啦. jdk有高级的API,我们为啥还要自己去实现呢,问题就是我们不知道. 所以,我在这写个笔记,记录下,jdk 1.8 是怎么做的. /** * 计算两个时间点之间的天数 */ private static void getBetweenDay() { LocalDate start = LocalDate.of(2018, 2, 12); LocalDate now = Loca

  • java计算两个日期之前的天数实例(排除节假日和周末)

    如题所说,计算两个日期之前的天数,排除节假日和周末.这里天数的类型为double,因为该功能实现的是请假天数的计算,有请一上午假的为0.5天. 不够很坑的是每个日期都要查询数据库,感觉很浪费时间. 原则: 1.节假日存放在数据库中 实现步骤: 1.循环每个日期 2.判断每个日期是否为节假日或者为周末 3.若不是节假日和周末,天数+1 代码: public double calLeaveDays(Date startTime,Date endTime){ double leaveDays = 0;

  • 利用Java中Calendar计算两个日期之间的天数和周数

    前言 究竟什么是一个 Calendar 呢?中文的翻译就是日历,那我们立刻可以想到我们生活中有阳(公)历.阴(农)历之分.它们的区别在哪呢? 比如有: 月份的定义 - 阳`(公)历 一年12 个月,每个月的天数各不同:阴(农)历,每个月固定28天 每周的第一天 - 阳(公)历星期日是第一天:阴(农)历,星期一是第一天 实际上,在历史上有着许多种纪元的方法.它们的差异实在太大了,比如说一个人的生日是"八月八日" 那么一种可能是阳(公)历的八月八日,但也可以是阴(农)历的日期.所以为了计时

  • Java如何计算两个时间段内的工作日天数

    目录 计算两个时间段内的工作日天数 这种有两种方式可以解决 实现的大概原理就是 计算两个日期之间的周末天数 计算两个时间段内的工作日天数 一般在OA系统中都会遇到计算员工这段时间内的工作天数. 这种有两种方式可以解决 一是调用第三方服务接口进行计算 二是自己在系统中写代码计算 一的好处就是每年的节假日不用自己去维护直接用两个时间段就可以计算出来.但缺点是有些公司可以会和法定节假日期不一样那么这时候就计算不了了,还有就是一般这种OA的系统自己内部使用的话可能会部署在内网上那么就访问不了第三方接口了

  • java 判断两个时间段是否重叠的案例

    最近业务上遇到需要判断两个时间段是否存在重叠的情况,网上找了不少代码.大佬们的思路过于简洁了,有些理解不了.还只是个菜鸟码农,还是多锻炼锻炼自己的思路. 思路很简单:定义一个时间段的概念,既然是时间段就包含起始时间和终止时间这两个时间点.构造方法要保证起始时间在终止时间之前,这样才是一个有效的时间段概念. 为TimeSlot这个类定义四个比较先后顺序的方法,分别为:小于.大于.小于等于.大于等于.画张简单的时间线图理解一下就明白了.当整个时间段作为一个整体时,只有时间段小于或大于另一个时间段时,

  • PHP 计算两个时间段之间交集的天数示例

    废话不多说,我就直接上代码吧! /** * 计算两个时间段之间交集的天数 * @param $startDate1 开始日期1 * @param $endDate1 结束日期1 * @param $startDate2 开始日期2 * @param $endDate2 结束日期2 */ public function share_date_days($startDate1, $endDate1, $startDate2, $endDate2) { $days = 0; $startDate1 =

  • Python+SeaTable实现计算两个日期间的工作日天数

    目录 在 SeaTable 表格上新建 Python 脚本 思路 代码 总结 当我们计算两个日期间的间隔天数时,通常是用结束日期减去开始日期,但在实际的项目管理.任务管理.工作计划等场景中,某些时间段会涉及双休日.法定节假日,甚至还有公司自定义的工作时间安排,所以就需要计算出两个日期间的实际工作日天数.比如一个表格中有多条任务,每条任务都有各自的开始日期.计划结束日期或实际结束日期,那么如何自动计算出两个日期间的实际工作日天数,以便做到精细和量化呢. 此时,万能的 Python 就可以出场了,而

  • JavaScript计算两个日期时间段内日期的方法

    本文实例讲述了JavaScript计算两个日期时间段内日期的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: /*************************  * 计算两个日期时间段内所有日期  *   * @param value1  *            开始日期 YYYY-MM-DD  * @param value2  *            结束日期  * return 日期数组  */  function dataScope(value1, value2

  • Java 判断一个时间是否在另一个时间段内

          需求:当时间在凌晨0点至0点5分之间程序不执行. 也就是实现判断当前时间点是否在00:00:00至00:05:00之间 方法: Java代码 : /** * 判断时间是否在时间段内 * * @param date * 当前时间 yyyy-MM-dd HH:mm:ss * @param strDateBegin * 开始时间 00:00:00 * @param strDateEnd * 结束时间 00:05:00 * @return */ public static boolean i

  • 如何计算出当前日期属于定义时间段内的第几星期?

    如何计算出当前日期属于定义时间段内的第几星期?Function CalculateWeekNo(BeginDate,EndDate,InputDate)dim wdate(500,8)z=0x=0strlong=len(CStr(inputdate))-9inputdate=cdate(left(CStr(inputdate),strlong))for i=cdate(BeginDate) to cdate(EndDate)    if inputdate=i then    x=z    Ex

  • Java判断时间段内文件是否更新的方法

    本文实例讲述了Java判断时间段内文件是否更新的方法.分享给大家供大家参考.具体实现方法如下: 1.定时器 复制代码 代码如下: private Timer timer;    /** * 简易定时器 * @param delay  多久后开始执行.毫秒 * @param period 执行的间隔时间.毫秒 */  public void test(long delay, long period) {          timer = new Timer();          timer.sc

  • MyBatis中如何查询某个时间段内的数据

    目录 如何查询某个时间段内的数据 Mybatis查询日期范围 将日期时间,转换为字符串 将字符串,转换为日期时间 如何查询某个时间段内的数据 1.当使用SQL语句查询某个时间段的数据时 我们很自然的会想到使用between…and..来操作,但是如果使用between...and... 这个方法来查询某个时间段的数据时是需要传入两个参数的,一个是起始时间,另一个是结束时间,且两个参数必须要同时存在才能使用between...and...,而我们希望的是只传入一个参数(起始时间或者结束时间)就能进

随机推荐