(PHP 5 >= 5.3.0, PHP 7, PHP 8)
DatePeriod::__construct — Crée un nouvel objet DatePeriod
$start,$interval,$recurrences,$options = 0$start,$interval,$end,$options = 0Cette variante du constructeur a été rendu obsolète, utilisez DatePeriod::createFromISO8601String() à la place.
Crée un nouvel objet DatePeriod.
   Les objetsDatePeriod peuvent être utilisés comme itérateur pour
   générer un certain nombre d'objets DateTimeImmutable ou
   DateTime à partir d'une start
   date (date de début), un interval, et une end
   date (date de fin) ou du nombre de récurrences.
  
   La classe des objets renvoyés est équivalente à la classe ancêtre
   DateTimeImmutable ou DateTime
   fournis pas l'objet start.
  
startLa date de début de la période. Inclus par défaut dans le jeu de résultats.
intervalL'intervalle entre les récurrences de la période.
recurrences
       Le nombre de récurrences. Doit être plus grand que 0.
       Le nombre de résultats renvoyés est supérieur d'une unité, car la date de 
       début est incluse dans le jeu de résultats par défaut.
      
endLa date de fin de la période. Non inclus par défaut dans le jeu de résultats.
isostrUn sous-ensemble de la » spécification ISO 8601 de la répétition de l'intervalle.
Exemples de certaines fonctionnalités de spécification d'intervalle ISO 8601 que PHP ne prend pas en charge :
R0/)
        
       Z), tels que +02:00.
        
       optionsUn champ de bits qui peut être utilisé pour contrôler certains comportements avec les dates de début et de fin.
       Peut être configuré à DatePeriod::EXCLUDE_START_DATE
       pour exclure la date de début du jeu de dates de récursion dans
       la période.
      
       Peut être configuré à DatePeriod::INCLUDE_END_DATE
       pour inclure la date de fin du jeu de dates de récursion dans
       la période.
      
   Lance une exception DateMalformedPeriodStringException lorsque le paramètre
   isostr ne peut être analysé comme une période ISO 8601 valide.
   Antérieur à PHP 8.3, ceci était une Exception.
  
| Version | Description | 
|---|---|
| 8.3.0 | Lance désormais une DateMalformedPeriodStringException au lieu de Exception. | 
| 8.2.0 | La constante DatePeriod::INCLUDE_END_DATEa été ajoutée. | 
| 7.2.19, 7.3.6, 7.4.0 | recurrencesdoit désormais être plus grand que0. | 
Exemple #1 Exemple avec DatePeriod
<?php
$start = new DateTime('2012-07-01');
$interval = new DateInterval('P7D');
$end = new DateTime('2012-07-31');
$recurrences = 4;
$iso = 'R4/2012-07-01T00:00:00Z/P7D';
// Toutes ces périodes sont équivalentes.
$period = new DatePeriod($start, $interval, $recurrences);
$period = new DatePeriod($start, $interval, $end);
$period = new DatePeriod($iso);
// En parcourant l'objet DatePeriod, toutes les
// dates de la récursion pour la période seront affichées.
foreach ($period as $date) {
    echo $date->format('Y-m-d')."\n";
}
?>L'exemple ci-dessus va afficher :
2012-07-01 2012-07-08 2012-07-15 2012-07-22 2012-07-29
Exemple #2 Exemple avec DatePeriod et DatePeriod::EXCLUDE_START_DATE
<?php
$start = new DateTime('2012-07-01');
$interval = new DateInterval('P7D');
$end = new DateTime('2012-07-31');
$period = new DatePeriod($start, $interval, $end,
                         DatePeriod::EXCLUDE_START_DATE);
// En parcourant l'objet DatePeriod,
// toutes les dates de récursion pour la période sont affichées.
// Notez que, dans ce cas, 2012-07-01 ne sera pas affiché.
foreach ($period as $date) {
    echo $date->format('Y-m-d')."\n";
}
?>L'exemple ci-dessus va afficher :
2012-07-08 2012-07-15 2012-07-22 2012-07-29
Exemple #3 DatePeriod montrant tous les derniers jeudis du mois sur une année
<?php
$begin = new DateTime('2021-12-31');
$end = new DateTime('2022-12-31 23:59:59');
$interval = DateInterval::createFromDateString('last thursday of next month');
$period = new DatePeriod($begin, $interval, $end, DatePeriod::EXCLUDE_START_DATE);
foreach ($period as $dt) {
    echo $dt->format('l Y-m-d'), "\n";
}
?>L'exemple ci-dessus va afficher :
Thursday 2022-01-27 Thursday 2022-02-24 Thursday 2022-03-31 Thursday 2022-04-28 Thursday 2022-05-26 Thursday 2022-06-30 Thursday 2022-07-28 Thursday 2022-08-25 Thursday 2022-09-29 Thursday 2022-10-27 Thursday 2022-11-24 Thursday 2022-12-29
   Les nombres de répétitions non liés spécifiés dans la section 4.5 
   "Intervalle de temps récurrent" de la norme ISO 8601 ne sont pas 
   supportés, c'est-à-dire ni "R/..." comme 
   isostr ni  null comme 
   end ne fonctionnerait.
  
