首先說一下請假規則吧:
1、上午請假的,時間長度不得小於3小時
2、下午請假的,時間長度不得小於5小時
3、工作時間:9:00~18:00
4、中午有一小時非工作時間
因為公司的制度,加班沒有加班費但是可以調休,所以時間必須精確到小時。那麼問題來了:
1、如果我請假的時間跨度是上午到下午滿足規則,但是系統計算時間會多一小時:
2、如果有些人傻,選擇開始和結束時間的時候超出了工作時間,比如結束時間是18:00以後,那麼又要判斷是否要扣除18:00以後的時間
3、最麻煩的就是跨天,如果假期中包含法定假日、雙休等特殊情況。還有非整數跨天,比如只請到三天后的上午11點,那麼三天后的0:00~9:00這段時間怎麼去掉
思緒有些混亂,還請有經驗的前輩給分享一下經驗,謝謝!!
回複內容:
首先說一下請假規則吧:
1、上午請假的,時間長度不得小於3小時
2、下午請假的,時間長度不得小於5小時
3、工作時間:9:00~18:00
4、中午有一小時非工作時間
因為公司的制度,加班沒有加班費但是可以調休,所以時間必須精確到小時。那麼問題來了:
1、如果我請假的時間跨度是上午到下午滿足規則,但是系統計算時間會多一小時:
2、如果有些人傻,選擇開始和結束時間的時候超出了工作時間,比如結束時間是18:00以後,那麼又要判斷是否要扣除18:00以後的時間
3、最麻煩的就是跨天,如果假期中包含法定假日、雙休等特殊情況。還有非整數跨天,比如只請到三天后的上午11點,那麼三天后的0:00~9:00這段時間怎麼去掉
思緒有些混亂,還請有經驗的前輩給分享一下經驗,謝謝!!
跨天,其實和當天,沒區別,反正每天請假的時間都是9點到18點
先判斷
(開始-結束)/(24X3600)=天數,如果大於1,就說明是跨天的如:2016-08-30 10:30-2016-09-04 12:00,其實只要計算08-30和09-04這兩天的情況就好了,中間那幾天7*3=21小時
某天(上班+請假)
無非幾種情況,早上請假,下午請假,早上跨到下午
那if條件就麻煩了點
結束時間 <= 12點 早上請假
開始時間 >= 13點 && 結束時間 <= 18點 下午請假
剩下的基本就是跨段的,跨段分上午和下午來計算就好了。
0-9,12-13,18-0的時間段,有交叉的部分不計算就好了
你首先需要一個排班表用於判斷是否是工作日。如果小於9點,=9點,大於18點=18點,再用你1裡面說的方法不久完了。