[英]Calculate the weighted minutes between two dates in Excel
为方便起见,请将除数列表扩展为:
Interval 1 2 3 4 5 6 7
0700 - 0000 1 1 1 1 1 2 5
0000 -0700 4 4 4 4 4 8 16
假设您在A1:H3单元格中构建了表格,请贴上以下标签:
A6 ---> start time
A7 ---> end time
C5 ---> day
D5 ---> total minutes
E5 ---> before 0700 (2) or after (1)
F5 ---> devide by
G5 ---> calc
H8 ---> Sum
其中B6是您的开始时间值,而B7是您的结束时间值。
输入以下公式(并观察其工作原理):
C6 ---> =WEEKDAY(B6,2)
D6 ---> =24*60-HOUR(B6)*60-MINUTE(B6)
E6 ---> =IF(TIME(HOUR(B6),MINUTE(B6),SECOND(B6))>TIME(7,0,0),1,2)
F6 ---> =INDEX($B$2:$H$3,E6,MATCH(C6,$B$1:$H$1,0))
G6 ---> =D6/F6
并将其拖动到C7:G7。 除了
D7 ---> =(HOUR(B7))*60+MINUTE(B7)
G8 ---> =SUM(G6:G7)
它行得通吗? 如果您陷于理解公式中,请分享。
编辑(第2部分,基于注释+第3部分,重新创建新的示例文件后)
花点时间来了解所使用的序列/ excelFunction ...我已经将公式/键入序列嵌入为我想分享的“策略”的一部分。
假设开始日期/时间在A13中,而结束日期在B13中,则在这些标签上贴上:
A12 ----> start time
B12 ----> end time
C12 ----> dayNo
D12 ----> dateEachDay
E12 ----> before 7
F12 ----> after 7
G12 ----> divisor before 7
H12 ----> divisor after 7
I12 ----> sub total
A15 ----> dateForEquation
C18 ----> last day :
K19 ----> Sum
和这个值:
C13 ----> 1
首批公式(从日期/时间数据中获取仅日期数据):
A16 ----> =DATE(YEAR(A13),MONTH(A13),DAY(A13))
B16 ----> =DATE(YEAR(B13),MONTH(B13),DAY(B13))
C13 ----> 1
D13 ----> =A16
D18 ----> =B16
第2部分第1部分(第1天第n天的分钟数):
E13 ----> =IF(TIME(HOUR(A13),MINUTE(A13),SECOND(A13))<TIME(7,0,0),7*60-HOUR(A13)*60-MINUTE(A13),0)
F13 ----> =IF(TIME(HOUR(A13),MINUTE(A13),SECOND(A13))>=TIME(7,0,0),24*60-HOUR(A13)*60-MINUTE(A13),24*60-7*60)
E18 ----> =IF(TIME(HOUR(B13),MINUTE(B13),SECOND(B13))<TIME(7,0,0),HOUR(B13)*60-MINUTE(B13),7*60)
F18 ----> =IF(TIME(HOUR(B13),MINUTE(B13),SECOND(B13))>TIME(7,0,0),HOUR(B13)*60+MINUTE(B13)-420,0)
第二批第2部分(全天之间的分钟数),需要拖动到F17:
C14 ----> =IF(D14="",0,7*60)
D14 ----> =IF(D14="",0,17*60)
E14 ----> =IFERROR(INDEX($B$3:$H$3,MATCH(WEEKDAY($D14,2),$B$1:$H$1,0)),1)
F14 ----> =IFERROR(INDEX($B$2:$H$2,MATCH(WEEKDAY($D14,2),$B$1:$H$1,0)),1)
第三批,(使用index()n match()获得各自的除数+ calc)拖动到J18:
G13 ----> =IFERROR(INDEX($B$3:$H$3,MATCH(WEEKDAY($D13,2),$B$1:$H$1,0)),1)
H13 ----> =IFERROR(INDEX($B$2:$H$2,MATCH(WEEKDAY($D13,2),$B$1:$H$1,0)),1)
I13 ----> =E13/G13
J13 ----> =F13/H13
最后..
J19 ----> =SUM(I13:J18)
如果您对理解它有所了解,就嗡嗡作响。。但是请帮助我仔细检查(手动计算?)..(:
编辑(第3部分,基于“结束时间(B13)在27-02-2018 21:20:00”的情况)
由于是同一天。.使用A21作为开始日期/时间,并使用B21作为结束日期/时间..
在A22,使用=DATE(YEAR(A21),MONTH(A21),DAY(A21))
提取日期。
在B22,使用WEEKDAY(A22,2)
获取日期的工作日...
然后在C22使用=IF(TIME(HOUR(A21),MINUTE(A21),SECOND(A21))>TIME(7,0,0),0,IF(TIME(HOUR(B21),MINUTE(B21),SECOND(B21))>TIME(7,0,0),7*60-(HOUR(A21)*60+MINUTE(A21)),HOUR(B21)*60+MINUTE(B21))-(HOUR(A21)*60+MINUTE(A21)))
获得0700小时之前的分钟=IF(TIME(HOUR(A21),MINUTE(A21),SECOND(A21))>TIME(7,0,0),0,IF(TIME(HOUR(B21),MINUTE(B21),SECOND(B21))>TIME(7,0,0),7*60-(HOUR(A21)*60+MINUTE(A21)),HOUR(B21)*60+MINUTE(B21))-(HOUR(A21)*60+MINUTE(A21)))
在D22处,使用=IF(TIME(HOUR(B21),MINUTE(B21),SECOND(B21))<TIME(7,0,0),HOUR(B21)*60+MINUTE(B21)-7*60,HOUR(B21)*60+MINUTE(B21)-(HOUR(A21)*60+MINUTE(A21)))
获得0700小时后的分钟数=IF(TIME(HOUR(B21),MINUTE(B21),SECOND(B21))<TIME(7,0,0),HOUR(B21)*60+MINUTE(B21)-7*60,HOUR(B21)*60+MINUTE(B21)-(HOUR(A21)*60+MINUTE(A21)))
使用索引/匹配函数,以及在B22定义的工作日,使用=IFERROR(INDEX($B$3:$H$3,MATCH(WEEKDAY($A22,2),$B$1:$H$1,0)),1)
& =IFERROR(INDEX($B$2:$H$2,MATCH(WEEKDAY($A22,2),$B$1:$H$1,0)),1)
。
并使用G22和H22处的=C22/E22
和=D22/F22
将分钟除以其除数。
最终使用=SUM(G22:H22)
@ H3获得总和
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.