乔山办公网我们一直在努力
您的位置:乔山办公网 > excel表格制作 > 如何用EXCEL计算两个日期之间相差的年数和月数?-excel年月计算,excel计算日期时间差年月

如何用EXCEL计算两个日期之间相差的年数和月数?-excel年月计算,excel计算日期时间差年月

作者:乔山办公网日期:

返回目录:excel表格制作


可以使用DATEDIF函数。
DATEDIF函数,主要用于计算两个日期之间的天数、月数或年数。其返回的值是两个日期之间的年\月\日间隔数。

基本语法

DATEDIF(Start_Date,End_Date,Unit)

Start_Date:为一个日期,它代表时间段内的第一个日期或起始日期;

End_Date:为一个日期,它代表时间段内的最后一个日期或结束日期;

Unit:为所需信息的返回类型。
举例:1975年1月30日与今天总共相差了487个月。


在C1输入=IF((YEAR(A1)=YEAR(B1))*(MONTH(A1)=MONTH(B1)),0,(YEAR(B1)-YEAR(A1))*12+MONTH(B1)+IF(DAY(B1)-15>0,1,0.5)-(MONTH(A1)+IF(DAY(A1)-15>0,1,0.5)))+0.5
为了让你好理解,将公式拆解为如下:=IF(X,0,Y)如果条件X成立,返回0,否则返回Y
其中e5a48de588b6e799bee5baa6335X为(YEAR(A1)=YEAR(B1))*(MONTH(A1)=MONTH(B1))意思是如果A1的年份和B1的相同且A1的月份和B1的月份相同每个等式会返回TRUE(真)后者FALSE(假),真*真为真,其他情况为假。
Y为(YEAR(B1)-YEAR(A1))*12+MONTH(B1)+IF(DAY(B1)-15>0,1,0.5)-(MONTH(A1)+IF(DAY(A1)-15>0,1,0.5))+0.5简化为P-Q+0.5P为(YEAR(B1)-YEAR(A1))*12+MONTH(B1)+IF(DAY(B1)-15>0,1,0.5)Q为MONTH(A1)+IF(DAY(A1)-15>0,1,0.5)意思把A1、B1分别转化为两个小数,整数部分代表月,小数部分代表半个月。
Q好理解:A1的月份加上,如果A1的日比15大就是1,小于等于15为0.5。
P一样,只是考虑了年的影响:(YEAR(B1)-YEAR(A1))*12,即年份的差乘以12(1年12个月)
最后一个0.5是因为你要求连“皮”计算(比如1号到2号是几天,有人认为是1,有人认为是2-1+1共2天)。

相关阅读

关键词不能为空
极力推荐

ppt怎么做_excel表格制作_office365_word文档_365办公网