百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

如何计算每月应出勤天数,如有法定假期和调休,如何计算

liuian 2025-05-11 17:09 13 浏览

本文介绍如何计算每月的应出勤天数。第一部分介绍正常双休制下计算应出勤天数;第二部份介绍当月有法定假期和调休的情况下计算应出勤天数。

一、计算正常双休制的应出勤天数

如下图所示,要求计算各员工2021年3月的应出勤天数。需要注意的是,当月有两位员工新入职。

在E2单元格输入公式 =NETWORKDAYS(IF(D2<$H$1,$H$1,D2),$H$2)


公式解析

(1)NETWORKDAYS函数用于计算两个日期之间的工作日数,其语法为NETWORKDAYS(start_date,end_date,[holidays])。其中,start_date代表开始日期,end_date代表终止日期。NETWORKDAYS默认周六、周日为非工作日。如果当月有法定假期,则使用参数holidays表示。

(2)IF(D2<$H$1,$H$1,D2)表示如果员工在当月1号之前入职,则以当月1号作为计算工作日天数的起始日期;如果员工在当月1号当日或之后入职,则以入职当天作为计算工作日天数的起始日期。

(3)由于3月没有法定假期,因此省略参数holidays。


二、计算有法定假期和调休的应出勤天数

如下图所示,要求计算各员工2021年4月的应出勤天数。

需要注意的是,4月有三天清明节法定假期,而且4月25日要进行五一调休。4月份日历如下图所示:

在E2单元格输入公式

=NETWORKDAYS(IF(D2<$H$1,$H$1,D2),$H$2,$H$3:$H$5)+IF(D2>$H$6,0,1)


公式解析:

(1)IF(D2<$H$1,$H$1,D2)用于判断入职日期和当月1日两者孰晚,以较晚的日期作为计算工作日天数的起始日期。

(2)$H$3:$H$5用于指定清明节法定假期。

(3)IF(D2>$H$6,0,1)指如果在五一调休之后入职,则应出勤天数加0(即不涉及调休);如果在五一调休之前或当日入职,则应出勤天数加1。

相关推荐

那些Java架构师必知必会的技术

Java基础#Java对象的内存布局MapStruct解了对象映射的毒周末我把HashMap源码又过了一遍Java7和Java8中的ConcurrentHashMap原理解析Java中自定...

Java内存泄漏最全详解(6大原因及解决方案)

大家好,我是mikechen。内存泄漏是经常出现的线上故障,也是大厂面试经常考察的,下面我就全面来详解内存泄漏以及解决方案@mikechen本篇已收于mikechen原创超30万字《阿里架构师进阶专题...

都说Feign是RPC,没有侵入性,为什么我的代码越来越像 C++

1.概览随着SpringCloud的流行性,Feign已经成为RPC的事实标准,由于其构建与Http协议之上,对请求和返回值缺少规范约束,在日常开发过程中经常由于设计不当对系统造成一...

面试题系列-java后端面试题List 和 Set 的区别

List和Set的区别List,Set都是继承自Collection接口List特点:元素有放入顺序,元素可重复,Set特点:元素无放入顺序,元素不可重复,重复元素会覆盖掉,(...

一直不理解为什么在重写equals方法时都要重写hashCode方法

为什么在重写equals方法时都要重写hashCode方法呢?首先jdk的要求是这样的,equals与hashcode间的关系:1、如果两个对象相同(即用equals比较返回true),那么它们的ha...

翻了ConcurrentHashMap1.7 和1.8的源码,我总结了它们的主要区别

ConcurrentHashMap思考:HashTable是线程安全的,为什么不推荐使用?HashTable是一个线程安全的类,它使用synchronized来锁住整张Hash表来实现线程安全,即每次...

10 个经典的 Java 集合面试题,看你能否答得上来?

来自:evget.com/article/2014/11/27/21869.html这里有10个经典的Java面试题,也为大家列出了答案。这是Java开发人员面试经常容易遇到的问题,相信你了解和掌握之...

MyBatis3.5.11-从入门到高阶

一.课程介绍MyBatis概述MyBatis基础应用MyBatis高级MyBatis进阶二.MyBatis概述1、为什么需要MyBatis在我们程序中,运行时期产生的数据都是存放在内存中的,那么在内存...

灵魂拷问:如何检查 Java 数组中是否包含某个值?

作者|沉默王二责编|Elle在逛programcreek的时候,我发现了一些专注细节但价值连城的主题。比如说:如何检查Java数组中是否包含某个值?像这类灵魂拷问的主题,非常值得深入地研...

Java后端学习路线是什么?

关于Java后端(SpringBoot为主)学习路线:一、Java基础阶段编程语言基础掌握基本数据类型(如int、double、char等)、变量、常量的定义和使用。理解运算符(算术、关...

Mybatis配置文件XML全貌详解,再不懂我也没招了

一、为什么要使用配置文件试想,如果没有配置文件,我们的应用程序将只能沿着固定的姿态运行,几乎不能做任何动态的调整,那么这不是一套完美的设计,因为我们希望拥有更宽更灵活的操作空间和更多的兼容度,同时也能...

软件性能调优全攻略:从瓶颈定位到工具应用

性能调优是软件测试中的重要环节,旨在提高系统的响应时间、吞吐量、并发能力、资源利用率,并降低系统崩溃或卡顿的风险。通常,性能调优涉及发现性能瓶颈、分析问题根因、优化代码和系统配置等步骤,调优之前需要先...

你还在使用Guava的Lists.newArrayList()吗

Guava说起Guava,做Java开发的应该没人不知道吧,毕竟“google出品,必属精品”。虽然应该没有Spring那样让Javaer无法避开,但是其中很多工具类的封装还是让人欲罢不能。而我们今天...

JDK成长记7:3张图搞懂HashMap底层原理

HashMap基本原理和优缺点HashMap基本原理和优缺点一句话讲,HashMap底层数据结构,JDK1.7数组+单向链表、JDK1.8数组+单向链表+红黑树。HashMap的3个底层原理Hash...

如何深度理解mybatis?

深度自定义mybatis回顾mybatis的操作的核心步骤编写核心类SqlSessionFacotryBuild进行解析配置文件深度分析解析SqlSessionFacotryBuild干的核心工作编写...