Java 计算一段时间段内除去周六日、节假日的工作日数‘’
实现功能提要: 本文章记录的是某段时间的起止时间段内的工作日,既是除去周六周日以及节假日日期的工作日数;
注释比较多,因为怕自己忘记,写的可能比较啰嗦~;
1、前端界面简介
其他的先不考虑,主要是由前台传递到后台的假期开始时间和结束时间;
2、后台处理代码
此段直接进入正题,处理代码我封装到Utils工具类中了,因此关于接收前台时间数据、方法的调用以及参数的传递就不在细说,只提一点就是:传到工具类中的参数有三个,分别是假期开始、假期结束时间以及假期信息表的service对象~
代码部分:
package cn.com.ikdo.oa.leave.utils;
/**
* @Descript: 工作日计算
*/
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import cn.com.oa.leave.entity.OaAttendanceVacation; // 假期信息实体类
import cn.com.oa.leave.service.OaAttendanceVacationService; // 假期信息表的service对象
public class DutyDaysUtils {
@SuppressWarnings("deprecation")
public static float getDutyDays(Date startDate, Date endDate, OaAttendanceVacationService oaAttendanceService) {
/*
此处 result 的返回值及其类型是因为数据库中与之相关的数据是float类型的,因此设置成这样,
有需要的童鞋可以根据个人情况而定————设置成这样的目的是为了能存储带小数点的数字
*/
Float result = 0F;
/*
此处一定要new两个时间对象进行接收传递来的参数,否则会在之后保存请假的起止日期时
发现用户选择的起止日期和数据库中的日期不一致,原因就在于下面的代码会操作开始日期
并使其发生改变,而结束日期不会变化,但是还是都统一处理一下的好(强迫症~)
*/
Date startDates = new Date(startDate.getTime());
Date endDates = ne