ZetCode

PHP Carbon

最后修改于 2025 年 2 月 16 日

PHP Carbon 教程展示了如何使用 Carbon 包在 PHP 中处理日期和时间。我们使用 nesbot/carbon 包。

PHP Carbon

Carbon 是一个 PHP 日期时间库。它是 PHP DateTime 类的扩展。

PHP Carbon 设置

该包使用 composer 安装。

$ composer req nesbot/carbon

我们安装 nesbot/carbon 包。

Carbon 今天

以下示例展示了如何获取今天的日期。

today.php
<?php

require __DIR__ . '/vendor/autoload.php';

use Carbon\Carbon;

$now = Carbon::now();
echo "$now\n";

$today = Carbon::today();
echo "$today\n";

Carbon::now 返回当前日期和时间,Carbon:today 返回当前日期。

$ php today.php
2022-07-13 15:53:45
2022-07-13 00:00:00

Carbon::yesterday 创建昨天的 Carbon 实例,Carbon::tomorrow 创建明天的 Carbon 实例。

yes_tom.php
<?php

require __DIR__ . '/vendor/autoload.php';

use Carbon\Carbon;

$yes = Carbon::yesterday();
echo "Yesterday: $yes\n";

$tom = Carbon::tomorrow();
echo "Tomorrow: $tom\n";

该示例展示了昨天和明天的日期。

$ yes_tom.php
Yesterday: 2022-07-12 00:00:00
Tomorrow: 2022-07-14 00:00:00

Carbon create

可以使用多种创建方法创建 Carbon 实例。

create.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

$d1 = Carbon::create(2018, 8, 25, 22, 48, 00);
echo $d1 . "\n";

$d2  = Carbon::create(2018, 8, 25, 22, 48, 00, 'Europe/Moscow');
echo $d2 . "\n";

$d3 = Carbon::createFromDate(2018, 8, 14, 'America/Chicago');
echo $d3 . "\n";

$d4 = Carbon::createFromTimestamp(1);
echo $d4 . "\n";

该示例使用四种不同的方法创建 Carbon 实例。

$d1 = Carbon::create(2018, 8, 25, 22, 48, 00);

create 方法从日期和时间部分生成一个 Carbon 实例。

$d2  = Carbon::create(2018, 8, 25, 22, 48, 00, 'Europe/Moscow');

在第二个示例中,我们还提供了时区。

$d3 = Carbon::createFromDate(2018, 8, 14, 'America/Chicago');

使用 createFromDate,我们使用日期部分创建一个 Carbon 实例。

$d4 = Carbon::createFromTimestamp(1);

createFromTimestamp 从 Unix 时间创建一个 Carbon 实例。

$ php create.php
2018-08-25 22:48:00
2018-08-25 22:48:00
2018-08-14 03:33:16
1970-01-01 01:00:01

Carbon 相对修饰符

Carbon 实例可以从相对修饰符创建,例如下个星期五或一年前。

relative_modifiers.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

echo new Carbon('tomorrow') . "\n";
echo new Carbon('yesterday') . "\n";
echo new Carbon('next wednesday') . "\n";
echo new Carbon('last friday') . "\n";
echo new Carbon('this saturday') . "\n";
echo new Carbon('1 year ago') . "\n";

该示例使用几个修饰符创建 Carbon 实例。

$ php relative_modifiers.php
2022-07-14 00:00:00
2022-07-12 00:00:00
2022-07-20 00:00:00
2022-07-08 00:00:00
2022-07-16 00:00:00
2021-07-13 15:55:09

Carbon next & previous

nextprevious 方法给出给定星期几的下一个/上一个出现日期。

next_previous.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

$now = Carbon::now();

echo "$now\n";

$next_monday = $now->next(Carbon::MONDAY);
echo "Next monday: $next_monday\n";

$prev_monday = $now->previous(Carbon::MONDAY);
echo "Previous monday: $prev_monday\n";

该示例展示了下个和上个星期一。

$ php next_previous.php
2022-07-13 15:55:51
Next monday: 2022-07-18 00:00:00
Previous monday: 2022-07-11 00:00:00

Carbon 日期时间部分

一个 Carbon 日期时间由包括年、月、日或小时的部分组成。

parts.php
<?php

require __DIR__ . '/vendor/autoload.php';

use Carbon\Carbon;

$now = Carbon::now();

echo $now->year  . "\n";
echo $now->month  . "\n";
echo $now->day  . "\n";
echo $now->hour  . "\n";
echo $now->second  . "\n";
echo $now->dayOfWeek  . "\n";
echo $now->dayOfYear  . "\n";
echo $now->weekOfMonth  . "\n";
echo $now->daysInMonth  . "\n";

该示例显示了 Carbon 日期时间实例的各个部分。

$ php parts.php
2022
7
13
15
17
3
194
2
31

Carbon 流畅 API

Carbon 还提供了方便的流畅 API 来处理日期时间。

fluent_api.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

$dt = Carbon::create();
$dt->year(2019)->month(5)->day(6)->hour(16)->minute(12)->second(53);
echo $dt . "\n";

$dt2 = Carbon::create();
$dt2->setDate(2019, 5, 6)->setTime(16, 12, 53);
echo $dt2 . "\n";

$dt3 = Carbon::create();
$dt3->setDate(2019, 5, 6)->setTime(16, 12, 53);
echo $dt3 . "\n";

该示例使用流畅 API 创建了三个 Carbon 实例。

$ php fluent_api.php
2019-05-06 16:12:53
2019-05-06 16:12:53
2019-05-06 16:12:53

Carbon copy 方法

Carbon 修改方法会修改实例。我们可以使用 copy 方法来处理副本。

copy_method.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

echo "Tomorrow: " . Carbon::tomorrow() . "\n";

echo "*************************\n";

$dt = new Carbon('tomorrow');
echo $dt->subDay() . "\n";
echo $dt . "\n";

echo "*************************\n";

$dt2 = new Carbon('tomorrow');
echo $dt2->copy()->subDay() . "\n";
echo $dt2 . "\n";

该示例介绍了 copy 方法。

$ php copy_method.php
Tomorrow: 2022-07-14 00:00:00
*************************
2022-07-13 00:00:00
2022-07-13 00:00:00
*************************
2022-07-13 00:00:00
2022-07-14 00:00:00

在第二种情况下,原始实例保持不变。

Carbon 加法/减法方法

Carbon 提供了几种不同的方法,可以轻松地添加和减去时间。

add_sub.php
<?php

require __DIR__ . '/vendor/autoload.php';

use Carbon\Carbon;

$now = Carbon::now();

echo "$now\n";

$d1 = $now->copy()->addDays(3);
echo "$d1\n";

$d2 = $now->copy()->addHours(12);
echo "$d2\n";

$d3 = $now->copy()->subDays(3);
echo "$d3\n";

$d4 = $now->copy()->subHours(12);
echo "$d4\n";

该示例介绍了 addDaysaddHourssubDayssubHours 方法。

$ php add_sub.php
2022-07-13 15:57:59
2022-07-16 15:57:59
2022-07-14 03:57:59
2022-07-10 15:57:59
2022-07-13 03:57:59

以下示例展示了其他加法和减法方法。

add_sub.php
<?php

require __DIR__ . '/vendor/autoload.php';

use Carbon\Carbon;

$now = Carbon::now();

$d1 = $now->copy()->addCenturies(2);
echo $d1->toDateString() . "\n";

$d2 = $now->copy()->subCenturies(2);
echo $d2->toDateString() . "\n";

$d3 = $now->copy()->addYears(2);
echo $d3->toDateString() . "\n";

$d4 = $now->copy()->subYears(2);
echo $d4->toDateString() . "\n";

$d5 = $now->copy()->addMonths(2);
echo $d5->toDateString() . "\n";

$d6 = $now->copy()->subMonths(2);
echo $d6->toDateString() . "\n";

我们展示了 addCenturiessubCenturiesaddYearssubYearsaddMonthssubMonths

$ php add_sub2.php
2222-07-13
1822-07-13
2024-07-13
2020-07-13
2022-09-13
2022-05-13

Carbon 格式化日期时间

Carbon 提供了几种格式化日期时间的方法。

formatting.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

$dt = Carbon::now();

echo $dt . "\n";
echo $dt->toDateTimeString(). "\n";

echo "******************************\n";

echo $dt->toDateString(). "\n";
echo $dt->toFormattedDateString(). "\n";
echo $dt->toTimeString(). "\n";
echo $dt->toDayDateTimeString(). "\n";

echo "******************************\n";

echo $dt->format('Y-m-d h:i:s A'). "\n";

该示例提供了基本的格式化方法。我们还可以使用 format 生成自定义格式。

$ php formatting.php
2022-07-13 15:58:58
2022-07-13 15:58:58
******************************
2022-07-13
Jul 13, 2022
15:58:58
Wed, Jul 13, 2022 3:58 PM
******************************
2022-07-13 03:58:58 PM

以下示例展示了其他常见的 Carbon 日期时间格式化方法。

common_formats.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

$dt = Carbon::createFromFormat('Y-m-d H:i:s.u', '2019-05-06 16:45:00.613484');

echo $dt->toAtomString() . "\n";
echo $dt->toCookieString() . "\n";

echo $dt->toIso8601String() . "\n";
echo $dt->toIso8601ZuluString() . "\n";

echo $dt->toRfc822String() . "\n";
echo $dt->toRfc850String() . "\n";
echo $dt->toRfc1036String() . "\n";
echo $dt->toRfc1123String() . "\n";
echo $dt->toRfc3339String() . "\n";
echo $dt->toRfc7231String() . "\n";

echo $dt->toRssString() . "\n";
echo $dt->toW3cString() . "\n";

该示例介绍了其他十二种方法。

$ php common_formats.php
2019-05-06T16:45:00+02:00
Monday, 06-May-2019 16:45:00 CEST
2019-05-06T16:45:00+02:00
2019-05-06T14:45:00Z
Mon, 06 May 19 16:45:00 +0200
Monday, 06-May-19 16:45:00 CEST
Mon, 06 May 19 16:45:00 +0200
Mon, 06 May 2019 16:45:00 +0200
2019-05-06T16:45:00+02:00
Mon, 06 May 2019 14:45:00 GMT
Mon, 06 May 2019 16:45:00 +0200
2019-05-06T16:45:00+02:00

Carbon 比较日期时间

Carbon 具有用于比较日期时间的诸如 eqgt 之类的方法。

comparing.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

$first = Carbon::create(2019, 5, 5, 22, 20, 1);
$second = Carbon::create(2019, 5, 5, 20, 20, 1);

echo $first . "\n";
echo $second . "\n";

var_dump($first->eq($second));
var_dump($first->ne($second));
var_dump($first->gt($second));
var_dump($first->gte($second));
var_dump($first->lt($second));
var_dump($first->lte($second));

该示例比较了两个日期时间值。

$ php comparison.php
2019-05-05 22:20:01
2019-05-05 20:20:01
bool(false)
bool(true)
bool(true)
bool(true)
bool(false)
bool(false)

Carbon UTC

协调世界时 (UTC) 是世界用于调节时钟和时间的主要时间标准。

utc.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

$now = Carbon::now();
echo "$now\n";
isUtc($now);

echo "Offset hours: {$now->offsetHours}\n";

echo "******************************\n";

$now->tz('UTC');
echo "$now\n";
isUtc($now);

function isUtc($now): void
{
    if ($now->utc)
    {
        echo "Datetime is in UTC\n";
    } else {

        echo "Datetime is not in UTC\n";
    }
}

该示例计算了 UTC 时间、小时偏移量,并确定日期时间是否为 UTC 时间。

$ php utc.php
2022-07-13 15:59:49
Datetime is not in UTC
Offset hours: 2
******************************
2022-07-13 13:59:49
Datetime is in UTC

Carbon 人性化日期时间差异

应用程序通常以所谓的人性化格式显示日期时间差异;例如,一年后或 3 分钟前。

humanized.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

echo Carbon::now()->addYear()->diffForHumans() . "\n";

Carbon::setLocale('de');
echo Carbon::now()->addYear()->diffForHumans() . "\n";

Carbon::setLocale('sk');
echo Carbon::now()->addYear()->diffForHumans() . "\n";

该示例展示了三种语言环境下的日期时间差异。

$ php humanize.php
11 months from now
in 11 Monaten
o 11 mesiacov

Carbon 修饰符

修饰符方法对当前实例执行有用的修改。它们可以检索一周、一个月或一年的开始/结束。

modifiers.php
<?php

require __DIR__ . "/vendor/autoload.php";

use Carbon\Carbon;

echo "Start/End of day\n";

$dt = Carbon::now();

echo $dt->copy()->startOfDay() . "\n";
echo $dt->copy()->endOfDay() . "\n";

echo "\nStart/End of month\n";

echo $dt->copy()->startOfMonth() . "\n";
echo $dt->copy()->endOfMonth() . "\n";

echo "\nStart/End of year\n";

echo $dt->copy()->startOfYear() . "\n";
echo $dt->copy()->endOfYear() . "\n";

echo "\nStart/End of decade\n";
echo $dt->copy()->startOfDecade() . "\n";
echo $dt->copy()->endOfDecade() . "\n";

echo "\nStart/End of century\n";
echo $dt->copy()->startOfCentury() . "\n";
echo $dt->copy()->endOfCentury() . "\n";

该示例介绍了几个修饰符。

$ php modifiers.php
Start/End of day
2022-07-13 00:00:00
2022-07-13 23:59:59

Start/End of month
2022-07-01 00:00:00
2022-07-31 23:59:59

Start/End of year
2022-01-01 00:00:00
2022-12-31 23:59:59

Start/End of decade
2020-01-01 00:00:00
2029-12-31 23:59:59

Start/End of century
2001-01-01 00:00:00
2100-12-31 23:59:59

来源

Carbon Github 存储库

在本文中,我们使用了 PHP Carbon 来处理日期和时间。

作者

我叫 Jan Bodnar,是一位充满激情的程序员,拥有丰富的编程经验。自 2007 年以来,我一直在撰写编程文章。到目前为止,我撰写了 1,400 多篇文章和 8 本电子书。我拥有十多年的编程教学经验。

列出所有 PHP 教程。