91

如何在 PHP 中获取两个日期之间的所有日期?更喜欢使用碳作为日期。

$from = Carbon::now();
$to = Carbon::createFromDate(2017, 5, 21);

我想要这两个日期之间的所有日期.. 但是如何?只能使用 strtotime 函数找到解决方案。

4

11 回答 11

174

从 Carbon 1.29 开始,可以执行以下操作:

$period = CarbonPeriod::create('2018-06-14', '2018-06-20');

// Iterate over the period
foreach ($period as $date) {
    echo $date->format('Y-m-d');
}

// Convert the period to an array of dates
$dates = $period->toArray();

有关更多详细信息,请参阅文档:https ://carbon.nesbot.com/docs/#api-period 。

于 2018-06-14T09:52:40.103 回答
73

这是我如何做到的Carbon

private function generateDateRange(Carbon $start_date, Carbon $end_date)
{
    $dates = [];

    for($date = $start_date->copy(); $date->lte($end_date); $date->addDay()) {
        $dates[] = $date->format('Y-m-d');
    }

    return $dates;
}
于 2016-01-26T18:25:07.780 回答
21

由于 Carbon 是 PHP 内置 DateTime 的扩展,您应该能够使用 DatePeriod 和 DateInterval,就像使用 DateTime 对象一样

$interval = new DateInterval('P1D');
$to->add($interval);
$daterange = new DatePeriod($from, $interval ,$to);

foreach($daterange as $date){
    echo $date->format("Ymd"), PHP_EOL;
}

编辑

如果需要包含期间的最终日期,则需要稍作修改,并$to在生成 DatePeriod 之前进行调整

$interval = new DateInterval('P1D');
$daterange = new DatePeriod($from, $interval ,$to);

foreach($daterange as $date){
    echo $date->format("Ymd"), PHP_EOL;
}
于 2015-08-06T07:32:20.927 回答
11

根据马克贝克的回答,我写了这个函数:

/**
 * Compute a range between two dates, and generate
 * a plain array of Carbon objects of each day in it.
 *
 * @param  \Carbon\Carbon  $from
 * @param  \Carbon\Carbon  $to
 * @param  bool  $inclusive
 * @return array|null
 *
 * @author Tristan Jahier
 */
function date_range(Carbon\Carbon $from, Carbon\Carbon $to, $inclusive = true)
{
    if ($from->gt($to)) {
        return null;
    }

    // Clone the date objects to avoid issues, then reset their time
    $from = $from->copy()->startOfDay();
    $to = $to->copy()->startOfDay();

    // Include the end date in the range
    if ($inclusive) {
        $to->addDay();
    }

    $step = Carbon\CarbonInterval::day();
    $period = new DatePeriod($from, $step, $to);

    // Convert the DatePeriod into a plain array of Carbon objects
    $range = [];

    foreach ($period as $day) {
        $range[] = new Carbon\Carbon($day);
    }

    return ! empty($range) ? $range : null;
}

用法:

>>> date_range(Carbon::parse('2016-07-21'), Carbon::parse('2016-07-23'));
=> [
     Carbon\Carbon {#760
       +"date": "2016-07-21 00:00:00.000000",
       +"timezone_type": 3,
       +"timezone": "UTC",
     },
     Carbon\Carbon {#759
       +"date": "2016-07-22 00:00:00.000000",
       +"timezone_type": 3,
       +"timezone": "UTC",
     },
     Carbon\Carbon {#761
       +"date": "2016-07-23 00:00:00.000000",
       +"timezone_type": 3,
       +"timezone": "UTC",
     },
   ]

您还可以传递一个布尔值 ( false) 作为第三个参数来排除结束日期。

于 2016-07-22T20:14:54.507 回答
6

这也可以这样做:

new DatePeriod($startDate, new DateInterval('P1D'), $endDate)

请记住这DatePeriod是一个迭代器,所以如果你想要一个实际的数组:

iterator_to_array(new DatePeriod($startDate, new DateInterval('P1D'), $endDate))

如果你使用 Laravel,你总是可以创建一个 Carbon 宏:

Carbon::macro('range', function ($start, $end) {
    return new Collection(new DatePeriod($start, new DateInterval('P1D'), $end));
});

现在你可以这样做:

foreach (Carbon::range($start, $end) as $date) {
   // ...
}
于 2017-11-25T12:18:22.967 回答
3

这是我所拥有的:

private function getDatesFromRange($date_time_from, $date_time_to)
    {

        // cut hours, because not getting last day when hours of time to is less than hours of time_from
        // see while loop
        $start = Carbon::createFromFormat('Y-m-d', substr($date_time_from, 0, 10));
        $end = Carbon::createFromFormat('Y-m-d', substr($date_time_to, 0, 10));

        $dates = [];

        while ($start->lte($end)) {

            $dates[] = $start->copy()->format('Y-m-d');

            $start->addDay();
        }

        return $dates;
    }

例子:

$this->getDatesFromRange('2015-03-15 10:10:10', '2015-03-19 09:10:10');
于 2015-09-10T11:37:46.203 回答
3

您不能直接使用循环控制变量,下一个必须可以正常工作

$start = Carbon::today()->startOfWeek();
$end = Carbon::today()->endOfWeek();

$stack = [];

$date = $start;
while ($date <= $end) {

    if (! $date->isWeekend()) {
        $stack[] = $date->copy();
    }
    $date->addDays(1);
}

return $stack;
于 2017-10-16T20:25:36.547 回答
2

您可以直接使用碳

    $start = Carbon::createFromDate(2017, 5, 21);
    $end = Carbon::now();

    while($start < $end){
        echo $start->format("M");
        $start->addMonth();
    }
于 2018-10-01T22:45:58.427 回答
-1

本教程将提供 laravel carbon 获取两个日期之间所有月份的示例。一步一步解释 laravel carbon 获取所有月份。这篇文章将为您提供有关日期之间所有月份的碳获取的简单示例。我们将使用获取两个日期之间的所有月份 laravel carbon。在这里,创建一个在两个日期之间获取月份的基本示例 laravel。

  
命名空间 App\Http\Controllers;
  
使用碳\碳;
使用碳\碳周期;
  
类 SignaturePadController 扩展控制器
{
    /**
     * 在方法上编写代码
     *
     * @return 响应()
     */
    公共函数索引()
    {
        $result = CarbonPeriod::create('2020-01-01', '2020-12-01');
  
        foreach ($result as $dt) {
            echo $dt->format("Ym");
        }
       $dates = $result->toArray();
    }
}

来源:https ://www.itsolutionstuff.com/post/laravel-carbon-get-all-months-between-two-dates-exampleexample.html

于 2021-05-06T04:42:27.610 回答
-2
//To get just an array of dates, follow this.


        $period = CarbonPeriod::create('2018-06-14', '2018-06-20');

        $p = array();
    // If you want just dates
    // Iterate over the period and create push to array
        foreach ($period as $date) {
            $p[] = $date->format('Y-m-d');
        }

    // Return an array of dates

        return $p;
于 2019-06-13T04:50:43.083 回答
-2

非常简单的解决方案(它适用于旧的 "<1.29" carbon ):

// set $start and $end to any date
$start = Carbon::now()->addDays(-10);
$end = Carbon::now();

$dates = [];
for($i = 0; $i < $end->diffInDays($start); $i++){
    $dates[] = (clone $start)->addDays($i)->format('Y-m-d');
}
dd($dates);
于 2020-05-01T09:42:53.357 回答