PHP jours ouvrables arrêt le week-end créer une nouvelle date de début lundi
Question
Salut je suis déjà en utilisant ce code d'une autre question - ce qui ajoute deux jours supplémentaires pour EndDay dans le cas de week-end
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);
}
Cette forme de fonction partie d'une sortie de json qui est affiché dans un calendrier jquery -. Il ramasse startdate et enddate et rend
Est-il possible de créer un code que le rendement des sorties de telle sorte que quand il arrive à un week-end, il crée une date de fin, permet de passer au lundi crée une date de début puis continue jusqu'à ce qu'il atteigne l'original donné enddate ??
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
La solution
Je ne suis pas 100% sûr de ce que la question / fonction fait vraiment, mais (si je devinai correctement) est ici une idée.
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);
}
La logique ajoute essentiellement en semaine $businessdays
à la date de début; vérifie ensuite les vacances dans la plage de dates, le cas échéant vacances se produisent alors la date limite est incrémentée selon le cas.