//휴일을 제외한 업무 일 수 계산
function getWorkingDays($startDate, $endDate, $holidays){
$endDate = strtotime($endDate);
$startDate = strtotime($startDate);
$days = ($endDate - $startDate) / 86400 + 1;
$no_full_weeks = floor($days / 7);
$no_remaining_days = fmod($days, 7);
$the_first_day_of_week = date("N", $startDate);
$the_last_day_of_week = date("N", $endDate);
if ($the_first_day_of_week <= $the_last_day_of_week) {
if ($the_first_day_of_week <= 6 && 6 <= $the_last_day_of_week) $no_remaining_days--;
if ($the_first_day_of_week <= 7 && 7 <= $the_last_day_of_week) $no_remaining_days--;
}
else {
if ($the_first_day_of_week == 7) {
$no_remaining_days--;
if ($the_last_day_of_week == 6) {
$no_remaining_days--;
}
}
else {
$no_remaining_days -= 2;
}
}
$workingDays = $no_full_weeks * 5;
if ($no_remaining_days > 0 )
{
$workingDays += $no_remaining_days;
}
//임시 휴일이 있다면 제외
foreach($holidays as $holiday){
$time_stamp=strtotime($holiday);
if ($startDate <= $time_stamp && $time_stamp <= $endDate && date("N",$time_stamp) != 6 && date("N",$time_stamp) != 7)
$workingDays--;
}
return $workingDays;
}
$holidays=array("2019-06-11","2020-07-01","2020-01-01");
echo getWorkingDays("2019-06-01","2019-07-01", $holidays)
'[ Web 관련 ] > php' 카테고리의 다른 글
CentOS + php + Oracle 연결 참조 (0) | 2019.06.21 |
---|---|
php 로그파일 만들기 (0) | 2019.06.20 |
두 날짜의 시간차이 구하기 (분) (0) | 2019.06.18 |
php 배열을 문자열로 변환 <-> 문자열을 배열로 변환, 그리고 배열확인, 세션에 배열 넣기 (0) | 2019.06.18 |
php 배열을 문자열로 변환 (0) | 2019.06.07 |