软件下载 点击激活 软件下载

DATEDIF,一个神奇的隐藏函数

DATEDIF是一个神奇的隐藏函数,它存在于Excel中,但是在帮助文件中却找不到它。

1

DATEDIF函数详解
DATEDIF的基础语法为:
 DATEDIF(开始日期,结束日期,间隔类型)  
 
其中,参数start_date和end_date是两个日期,并且前者一定不能大于后者。
unit有以下6个参数,分别用来计算不同的差异,如下表所示。
DATEDIF,一个神奇的隐藏函数
DATEDIF的参数

2

计算两个日期间的年、月、日间隔
如下图所示,这是DATEDIF的常规用法,这6个参数的实际意义,我们可以结合图中的数据进行讲解。

DATEDIF,一个神奇的隐藏函数

DATEDIF常规用法
首先,在D16、D24单元格中分别输入以下公式,向下分别复制到D21、D29单元格,以计算出不同参数的差异:
 =DATEDIF(E16,F16,C16)  
 =DATEDIF(E24,F24,C24)  
D24单元格,参数“Y”,单看2017年和2020年,相差年数应为3,但是从2017/7/28到2020/2/8,先过2年到2019/7/28,还没到要求的2020/2/8,再过1年的话,就到了2020/7/28,会超过结束日期,所以其结果返回2,不能返回3。
D25单元格,参数“M”,2017/7/28过30个月便到了2020/1/28,然后再过1个月就到了2020/2/28,超过了结束日期2020/2/8,所以结果只能为30,不能为31。要充分体会“整年数”“整月数”中“整”字的意思。
D26单元格,参数“D”,就相当于两个日期直接相减,计算天数的差。
D27单元格,参数“MD”,这个计算忽略月和年,相当于把start_date拉近到end_date 前最接近的日期。也就是说,将2017/7/28拉近到2020/2/8之前日期为28的最接近日期,即2020/1/28,然后计算2020/1/28与2020/2/8之间的天数差,即11天。
D28单元格,参数“YM”,忽略日和年计算整月数,即相当于把2017/7/28拉近到 2020/2/8之前最接近的7月28日,变成2019/7/28,然后计算其与2020/2/8之间的“整”月数差,即6个月。
D29单元格,参数“YD”,忽略年计算天数差,相当于把start_date拉近到end_date前最接近的相同月和相同日的日期。也就是说,将2017/7/28拉近到2019/7/28,然后计算2019/7/28与2020/2/8之间的天数差,即195天。 
在使用“MD”“YD”参数计算天数差时,由于闰年的存在,有时会与理想值相差一天,这种情况一般不会影响我们的日常使用。

3

整年、月、日区别
如下图所示,列出了2017/7/28到2020/7/27与2017/7/28到2020/7/28的对比,虽然end_date只差了1天,但是结果有比较大的差异。计算原理相同,要体会“整”字的含义。

DATEDIF,一个神奇的隐藏函数

整年、月、日区别
这么多参数需要怎么记忆呢?首先要知道这个函数的作用,理解每一个参数的计算原理。如果工作中常常需要计算日期,可以将其打印出来,贴在桌子旁即查即用。

4

案例:工龄计算
假定今天是2019/7/28,每个员工参加工作的日期如下图中C列所示,那么每个人的工龄是多少呢?工龄可表示成m年n个月的形式。

DATEDIF,一个神奇的隐藏函数

工龄计算
可以分步进行操作。首先计算“整年”数,然后计算“整月” 数。计算月数时需要注意,月数的值最大不会超过11,因为到12个月就是1年了,即要忽略年份的存在来计算月数。那么使用哪个参数计算呢?
从上一节讲的DATEDIF的参数对照表中可以看到,计算整年数使用参数“Y”,而忽略年计算整月数使用“YM”。于是D51单元格的函数公式可以写成:
左右拖动查看完整公式
=DATEDIF(C51,"2019/7/28","Y")&" 年 "&DATEDIF(C51,"2019/7/28","YM")&" 个月 "
我们看一下D54:D56单元格区域,仅相差1天,计算结果便不同。所以使用DATEDIF时,始终要有一个“整”的概念在脑海中。
另外,DATEDIF中的Y、M、D参数,大小写均可以。

5

案例:年假天数计算
《职工带薪年休假条例》规定,职工累计工作已满1年不满10年的,年休假为5天;已满10年不满20年的,年休假为10天;已满20年的,年休假为15天。
同样,假设今天是2019/7/28,那么每名员工的年休假天数分别为多少天呢?
其实这个题目比上一节的案例更简单,只需知道每名员工参加工作的年数即可。
如下图所示,在D66单元格中输入以下公式,计算出每名员工的工作年数:
 =DATEDIF(C66,DATE(2019,7,28),”Y”)  

DATEDIF,一个神奇的隐藏函数

年假天数计算
在这里再次强调,如果在公式中使用快捷输入的方式表达日期,必须加双引号,如上节中的“DATEDIF(C51,”2019/7/28″,”Y”)”。
根据D列的年数,可以计算法定年假的天数,在E66单元格中输入以下公式:
 =LOOKUP(D66,{0,1,10,20},{0,5,10,15})  
好了,今天的内容就是这些,祝大家一天好心情。

·END·

快速提取文件夹内的文件名

微信扫一扫加关注,Office自学网官方微信公众号,

专注分享软件安装和视频教程,让你一号在手,办公无忧!

 

给TA打赏
共{{data.count}}人
人已打赏
办公技巧

行列转换,这个公式挺好用

2022-11-8 14:45:23

办公技巧

字符拆分与合并,快速填充真轻松

2022-11-8 14:58:05

文章版权声明 1、本网站名称:office自学网
2、本站永久网址:https://www.officezxw.com/
3、本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长QQ:1241926466进行删除处理。
4、本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
5、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
6、本站资源大多存储在云盘,如发现链接失效,请联系我们我们会第一时间更新。

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索