2014-11-05 3 views
0

클래스 신청서를 작성할 때 예상 도착 날짜 형식을 지정해야합니다. 도착 예정일은 당일 기준으로 5 일 이상이 이상적입니다. 주말을 제외하고는 현재 하루에서 5 일을 정확하게 표시하는 방법조차 모르겠습니다. 주제에 대한 도움을 주시면 감사하겠습니다.PHP - 미래의 날짜 결정

나는 사이트의 다른 곳에서 본 다음 함수를 사용해 보았지만 함수를 전혀 사용할 수 없으며 코드를 붙여 넣기 만해도 어디서나 오류 메시지가 표시되지 않습니다. 이 응용 프로그램에서 다른 곳에서 사용할 수 없었기 때문에 strtotime() 함수와 관련이있을 수 있다고 생각합니다.

또한 가능한 한 모든 기능을 사용하지 않는 것이 좋습니다. 그 이유는이 기능과 관련된 내용의 절반을 이해하지 못하기 때문입니다. 내가 이해할 수있는 기능을 사용하는 것이 이상적입니다.

<?php 
//The function returns the no. of business days between two dates and it skips the holidays 
function getWorkingDays($startDate,$endDate,$holidays){ 
// do strtotime calculations just once 
$endDate = strtotime($endDate); 
$startDate = strtotime($startDate); 


//The total number of days between the two dates. We compute the no. of seconds and divide it to 60*60*24 
//We add one to inlude both dates in the interval. 
$days = ($endDate - $startDate)/86400 + 1; 

$no_full_weeks = floor($days/7); 
$no_remaining_days = fmod($days, 7); 

//It will return 1 if it's Monday,.. ,7 for Sunday 
$the_first_day_of_week = date("N", $startDate); 
$the_last_day_of_week = date("N", $endDate); 

//---->The two can be equal in leap years when february has 29 days, the equal sign is added here 
//In the first case the whole interval is within a week, in the second case the interval falls in two weeks. 
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 { 
    // (edit by Tokes to fix an edge case where the start day was a Sunday 
    // and the end day was NOT a Saturday) 

    // the day of the week for start is later than the day of the week for end 
    if ($the_first_day_of_week == 7) { 
     // if the start date is a Sunday, then we definitely subtract 1 day 
     $no_remaining_days--; 

     if ($the_last_day_of_week == 6) { 
      // if the end date is a Saturday, then we subtract another day 
      $no_remaining_days--; 
     } 
    } 
    else { 
     // the start date was a Saturday (or earlier), and the end date was (Mon..Fri) 
     // so we skip an entire weekend and subtract 2 days 
     $no_remaining_days -= 2; 
    } 
} 

//The no. of business days is: (number of weeks between the two dates) * (5 working days) + the remainder 
//---->february in none leap years gave a remainder of 0 but still calculated weekends between first and last day, this is one way to fix it 
$workingDays = $no_full_weeks * 5; 
if ($no_remaining_days > 0) 
{ 
    $workingDays += $no_remaining_days; 
} 

//We subtract the holidays 
foreach($holidays as $holiday){ 
    $time_stamp=strtotime($holiday); 
    //If the holiday doesn't fall in weekend 
    if ($startDate <= $time_stamp && $time_stamp <= $endDate && date("N",$time_stamp) != 6 && date("N",$time_stamp) != 7) 
     $workingDays--; 
} 

return $workingDays; 
} 

//Example: 

$holidays=array("2008-12-25","2008-12-26","2009-01-01"); 

echo getWorkingDays("2008-12-22","2009-01-02",$holidays) 
// => will return 7 
?> 
+1

'현재 날짜로부터 5 일을 정확하게 표시하는 법을 모르겠습니다.'매우 간단합니다. $ timestamp = strtotime ('+ 5 day'); 또는 http://php.net을보십시오. /manual/en/datetime.add.php – Cheery

+0

'영업일'이 무엇인지 더 자세히 알고 싶습니까? 정확히 월요일부터 금요일까지 또는 휴일 등을 고려해야합니까? –

답변

1

strtotime() 함수를 사용해야합니다.

논리 설명되는 바와 같이 :

  • 현재 날짜를 가지고 추가 오일
  • 를 날짜의 일 번호 6 (토) 또는 0 (일) 인 경우, 추가 2 1 더 많은 요일 각각

나는 그것을 XAMPP에서 테스트했으며 완벽하게 작동합니다!

function get_arrival_date($departure_date){ 

$arrival_date = date ('Y-m-d', strtotime ($departure_date. " +5 days")); 

$day_number = date("w", strtotime($arrival_date)); 

switch($day_number) 
    { 
     case "6": 
     $arrival_date = date ('Y-m-d', strtotime ($arrival_date. " +2 days")); 
     break; 

     case "0": 
     $arrival_date = date ('Y-m-d', strtotime ($arrival_date. " +1 days")); 
     break; 
    } 

return $arrival_date; 

} 

//End of function... Let's start with a little test 

//First you set the departure date in a variable. 
//You can even supply this value directly as a string '2014-12-20' or 
//retrieve it from mysql database if you want 

$date1 = date ('Y-m-d'); //Today (just and example) 

//Then you call the function and assign its result to a variable 

$date2= get_arrival_date($date1); //This variable holds the arrival date 

echo $date2; //Let's print the arrival date 

p.s.이 답변이 유용하다고 생각되면 유용한 것으로 표시하십시오.

관련 문제