Excel中求两个日期之间相隔的月数,我们通常使用DATEDIF函数来计算。
百度一下,网络上一大把的教程也是这么说的。我也曾经一度沾沾自喜,觉得自己多么能干,还知道DATEDIF这么好用的日期函数,甚至Excel帮助文档都查询不到这个函数。当经历这次惨痛的教训,或许有点明白微软为啥不公开这个函数,搞成隐藏函数,可能真的就是因为函数有些缺陷才没有公开吧。
DATEDIF函数计算日期相减得到月份数的基本语法: =DATEDIF(开始日期,结束日期,”m”),其中的参数“m”,表示计算日期之差的月数。
这个函数也不是不可以使用,只是必须注意下面细节!
1. NUM错误
=DATEDIF(开始日期,结束日期,"M"),结束日期必须大于开始日期。比如=DATEDIF(B1,A1,"y")就会出现报NUM!错误。
excel DATEDIF函数不仅可以用来计算年龄、工龄、工龄工资、项目周期,还可以用来做生日倒计时提醒,项目竣工日倒计时提醒等等
DATEDIF函数不仅可以用来计算年龄、工龄、工龄工资、项目周期,还可以用来做生日倒计时提醒,项目竣工日倒计时提醒等等。用上它,您再也不会缺席那些重要的日子,不论是亲人生日、项目
2. 提升月底天数优先级
DATEDIF函数只关注了日期的天信息,忽视了对月底信息的判断。所以我们真正在用这个函数的时候,遇到月底这种情况,就需要做优先级判断。正如案例第七行:周学的信息:2017/5/31 与 2017/6/30 都是月底,如果直接写:=DATEDIF(B7,C7,"m"),得到的结果就是错误的。
遇到日期都是月底这种情况,我们自己需要都留个心眼儿,把公式改进成:
=IF(DAY(日期 1)=1,日期 1,日期)
套进来就是:
=DATEDIF(IF(DAY(B7 1)=1,B7 1,B7),IF(DAY(C7 1)=1,C7 1,C7),"m")
这样就不会出错了。
你真的会用excel DATEDIF函数吗?为什么你算的出错了?的下载地址:
excel小技巧,10秒提取3000行有效数据!快快来get吧
问题来自于一位群友的求助,大家请看图(源数据较多,为方便讲解,省略为下图):数据源在A列,包含了很多项信息,现在需要从中提取出容值、封装和耐压三项数据,不难发现,需要提取