web-dev-qa-db-fra.com

J'ai 2 dates en PHP, comment puis-je exécuter une boucle foreach pour passer tous ces jours?

Je commence par une date 2010-05-01 et se termine par 2010-05-10. Comment puis-je parcourir toutes ces dates en PHP?

179
Shamoon

Nécessite PHP5.3:

$begin = new DateTime('2010-05-01');
$end = new DateTime('2010-05-10');

$interval = DateInterval::createFromDateString('1 day');
$period = new DatePeriod($begin, $interval, $end);

foreach ($period as $dt) {
    echo $dt->format("l Y-m-d H:i:s\n");
}

Cela affichera tous les jours de la période définie entre $start et $end. Si vous souhaitez inclure le 10ème, définissez $end sur 11. Vous pouvez ajuster le format à votre convenance. Voir le PHP Manuel pour DatePeriod .

477
Gordon

Cela comprend également la dernière date

$begin = new DateTime( "2015-07-03" );
$end   = new DateTime( "2015-07-09" );

for($i = $begin; $i <= $end; $i->modify('+1 day')){
    echo $i->format("Y-m-d");
}

Si vous n'avez pas besoin de la dernière date, supprimez simplement = de la condition.

82
Sabri Aziri

La conversion en horodatage Unix facilite le calcul de la date avec php:

$startTime = strtotime( '2010-05-01 12:00' );
$endTime = strtotime( '2010-05-10 12:00' );

// Loop between timestamps, 24 hours at a time
for ( $i = $startTime; $i <= $endTime; $i = $i + 86400 ) {
  $thisDate = date( 'Y-m-d', $i ); // 2010-05-01, 2010-05-02, etc
}

Lorsque vous utilisez PHP avec un fuseau horaire ayant l'heure d'été, veillez à ajouter une heure autre que 23h00, 00h00 ou 1h00 pour vous protéger des jours passés ou répétés.

35
Harold1983-
$startTime = strtotime('2010-05-01'); 
$endTime = strtotime('2010-05-10'); 

// Loop between timestamps, 1 day at a time 
$i = 1;
do {
   $newTime = strtotime('+'.$i++.' days',$startTime); 
   echo $newTime;
} while ($newTime < $endTime);

ou

$startTime = strtotime('2010-05-01'); 
$endTime = strtotime('2010-05-10'); 

// Loop between timestamps, 1 day at a time 
do {
   $startTime = strtotime('+1 day',$startTime); 
   echo $startTime;
} while ($startTime < $endTime);
14
Mark Baker

Copier un exemple de php.net pour inclus intervalle:

$begin = new DateTime( '2012-08-01' );
$end = new DateTime( '2012-08-31' );
$end = $end->modify( '+1 day' ); 

$interval = new DateInterval('P1D');
$daterange = new DatePeriod($begin, $interval ,$end);

foreach($daterange as $date){
    echo $date->format("Ymd") . "<br>";
}
12

Voici un autre simple -

/**
 * Date range
 *
 * @param $first
 * @param $last
 * @param string $step
 * @param string $format
 * @return array
 */
function dateRange( $first, $last, $step = '+1 day', $format = 'Y-m-d' ) {
    $dates = [];
    $current = strtotime( $first );
    $last = strtotime( $last );

    while( $current <= $last ) {

        $dates[] = date( $format, $current );
        $current = strtotime( $step, $current );
    }

    return $dates;
}

Exemple:

print_r( dateRange( '2010-07-26', '2010-08-05') );

Array (
    [0] => 2010-07-26
    [1] => 2010-07-27
    [2] => 2010-07-28
    [3] => 2010-07-29
    [4] => 2010-07-30
    [5] => 2010-07-31
    [6] => 2010-08-01
    [7] => 2010-08-02
    [8] => 2010-08-03
    [9] => 2010-08-04
    [10] => 2010-08-05
)
6
HADI

Utilisateur cette fonction: -

function dateRange($first, $last, $step = '+1 day', $format = 'Y-m-d' ) {
                $dates = array();
                $current = strtotime($first);
                $last = strtotime($last);

                while( $current <= $last ) {    
                    $dates[] = date($format, $current);
                    $current = strtotime($step, $current);
                }
                return $dates;
        }

Appel d'utilisation/de fonction: -

Augmenter d'un jour: -

dateRange($start, $end); //increment is set to 1 day.

Augmentation par mois: -

dateRange($start, $end, "+1 month");//increase by one month

utilisez le troisième paramètre si vous souhaitez définir le format de date: -

   dateRange($start, $end, "+1 month", "Y-m-d H:i:s");//increase by one month and format is mysql datetime
4
user2182143

voici un moyen:

 $date = new Carbon();
 $dtStart = $date->startOfMonth();
 $dtEnd = $dtStart->copy()->endOfMonth();

 $weekendsInMoth = [];
 while ($dtStart->diffInDays($dtEnd)) {

     if($dtStart->isWeekend()) {
            $weekendsInMoth[] = $dtStart->copy();
     }

     $dtStart->addDay();
 }

Le résultat de $ weekendsInMoth est un tableau de jours de week-end!

1
Jean Souza