programing

PHP에 날짜가 2개 있는데 어떻게 하면 그 모든 날짜를 통과시킬 수 있을까요?

minecode 2022. 10. 11. 21:25
반응형

PHP에 날짜가 2개 있는데 어떻게 하면 그 모든 날짜를 통과시킬 수 있을까요?

데이트부터 시작해요2010-05-01으로 끝나다2010-05-10어떻게 하면 PHP의 모든 날짜를 반복할 수 있을까요?

$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");
}

그러면 정의된 기간 내의 모든 날이 출력됩니다.$start그리고.$end. 10번째를 포함하려면,$end11번가로.원하는 대로 형식을 조정할 수 있습니다.DatePeriod에 대해서는, PHP 메뉴얼을 참조해 주세요.PHP 5.3이 필요합니다.

여기에는 마지막 날짜도 포함됩니다.

$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");
}

마지막 날짜가 필요 없는 경우 제거만 하면 됩니다.=상태로부터.

unix 타임스탬프로 변환하면 날짜 계산을 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
}

DST가 있는 시간대에서 PHP를 사용할 경우 건너뛰거나 반복되지 않도록 23:00, 00:00 또는 1:00 이외의 시간을 추가해야 합니다.

php.net 샘플에서 복사하여 포함 범위:

$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>";
}

여기 또 하나의 간단한 구현이 있습니다.

/**
 * 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;
}

예:

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
)
$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);

또는

$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);

사용자 이 기능:-

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;
        }

사용방법/함수 호출:-

하루 증가:-

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

월별 증가:-

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

날짜 형식을 설정하려면 세 번째 매개 변수를 사용합니다.-

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

위해서Carbon사용자

use Carbon\Carbon;

$startDay = Carbon::parse("2021-08-01");
$endDay= Carbon::parse("2021-08-05");
$period = $startDay->range($endDay, 1, 'day');

데이터를 인쇄할 때

[
     Carbon\Carbon @1627790400 {#4970
       date: 2021-08-01 00:00:00.0 America/Toronto (-04:00),
     },
     Carbon\Carbon @1627876800 {#4974
       date: 2021-08-02 00:00:00.0 America/Toronto (-04:00),
     },
     Carbon\Carbon @1627963200 {#4978
       date: 2021-08-03 00:00:00.0 America/Toronto (-04:00),
     },
     Carbon\Carbon @1628049600 {#5007
       date: 2021-08-04 00:00:00.0 America/Toronto (-04:00),
     },
     Carbon\Carbon @1628136000 {#5009
       date: 2021-08-05 00:00:00.0 America/Toronto (-04:00),
     },
]

이것은 Laravel 데이터 덤프입니다.dd($period->toArray());를 반복할 수 있게 되었습니다.$period원하신다면foreach진술.

가지 중요한 주의: 메서드에 제공된 에지 날짜가 모두 포함됩니다.

더 멋진 데이트에 대한 내용은 Carbon 문서를 참조하십시오.

방법은 다음과 같습니다.

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

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

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

     $dtStart->addDay();
 }

$weekends 결과InMoth는 주말의 연속이다!

$date = new DateTime($_POST['date']);
$endDate = date_add(new DateTime($_POST['date']),date_interval_create_from_date_string("7 days"));

while ($date <= $endDate) {
    print date_format($date,'d-m-Y')." AND END DATE IS : ".date_format($endDate,'d-m-Y')."\n";
    date_add($date,date_interval_create_from_date_string("1 days"));
}

이렇게 반복할 수도 있어요.$_POST['date']어플리케이션이나 웹사이트에서 흠집이 날 수 있습니다.$_POST['date']여기에 줄을 놓을 수도 있습니다."21-12-2019"둘 다 잘 될 거야

<?php

    $start_date = '2015-01-01';
    $end_date = '2015-06-30';

    while (strtotime($start_date) <= strtotime($end_date)) {
        echo "$start_daten";
        $start_date = date ("Y-m-d", strtotime("+1 days", strtotime($start_date)));
    }

?>

Larabel을 사용하고 Carbon을 사용하는 경우 올바른 솔루션은 다음과 같습니다.

$start_date = Carbon::createFromFormat('Y-m-d', '2020-01-01');
$end_date = Carbon::createFromFormat('Y-m-d', '2020-01-31');

$period = new CarbonPeriod($start_date, '1 day', $end_date);

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

다음 사항을 추가해 주십시오.

  • 카본\카본 사용
  • Carbon\CarbonPeriod 사용;

언급URL : https://stackoverflow.com/questions/3207749/i-have-2-dates-in-php-how-can-i-run-a-foreach-loop-to-go-through-all-of-those-d

반응형