PHP Business Days Stop nos fins de semana Crie uma nova data de início na segunda -feira

StackOverflow https://stackoverflow.com/questions/3439531

  •  27-09-2019
  •  | 
  •  

Pergunta

Oi já estou usando este código de outra pergunta - o que adiciona dois dias extras ao fim de dia no caso dos fins de semana

function add_business_days($startdate,$buisnessdays,$holidays,$dateformat){
  $i=1;
  $dayx = strtotime($startdate);
  while($i < $buisnessdays){
   $day = date('N',$dayx);
   $datex = date('Y-m-d',$dayx);
   if($day < 6 && !in_array($datex,$holidays))$i++;
   $dayx = strtotime($datex.' +1 day');
  }
  return date($dateformat,$dayx);
 }

Esta função faz parte de uma saída JSON exibida em um calendário de jQuery - ele pega o StartDate e o EndDate e o renderiza.

É possível criar um código que retorne resultados de modo que, quando chega a um fim de semana, cria uma data de término, pula para a segunda -feira cria uma data de início e continua até chegar ao final do final original?

x = date('w');
if (x != 6) {
while (x != 6) {
//start adding days to start date
}
} else {
//create new enddate = current iteration of dates currentdate;

//then new start (add two days to it to get to monday) currentdate + 2 = newstartdate
//redo above till you get to original end date
Foi útil?

Solução

Não tenho 100% de certeza sobre o que a pergunta/função está realmente fazendo, mas se adivinhei corretamente) aqui está uma ideia.

function add_business_days($startdate, $businessdays, $holidays, $dateformat)
{
    $start = new DateTime($startdate);
    $date  = new DateTime($startdate);
    $date->modify("+{$businessdays} weekdays");

    foreach ($holidays as $holiday) {
        $holiday = new DateTime($holiday);
        // If holiday is a weekday and occurs within $businessdays of the $startdate
        if ($holiday->format('N') < 6 && $holiday >= $start && $holiday <= $date) {
            $date->modify("+1 weekday");
        }
    }
    return $date->format($dateformat);
}

A lógica basicamente adiciona $businessdays dias da semana até a data de início; Em seguida, verifique se há feriados dentro do intervalo de data, se ocorrerem feriados, a data final será incrementada conforme apropriado.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top