ホームページ  >  記事  >  バックエンド開発  >  Carbon、Laravel の日時処理パッケージ

Carbon、Laravel の日時処理パッケージ

巴扎黑
巴扎黑オリジナル
2018-05-24 13:48:229155ブラウズ

日付の形式、タイムゾーン、閏年、日付が異なる月など、日付と時刻を処理する際には考慮すべき点がたくさんあります。次の記事では主に日付と時刻について紹介します。 Laravel の時間処理パッケージ Carbon 使い方は簡単なので、困っている友達は参考にしてください。

はじめに

PHP アプリケーションを作成するとき、日付と時刻を扱う必要があることがよくあります。この記事では、PHP DateTime クラスから継承された API 拡張機能である Carbon について説明します。これにより、日付と時刻の扱いが容易になります。日付と時刻付き。

Laravel で使用されるデフォルトの時間処理クラスは Carbon です。

<?php
namespace Carbon;
 
class Carbon extends \DateTime
{
 // code here
}

上記で宣言されたコード スニペットは、Carbon 名前空間の Carbon クラスで確認できます。

インストール

Carbon は Composer を通じてインストールできます:

composer require nesbot/carbon

PS: Laravel プロジェクトはデフォルトでこのパッケージをインストールしているため、上記のコマンドを再度実行する必要はありません。


を使用するには、名前空間を通じて Carbon をインポートし、毎回完全な名前を指定しなくても使用できるようにする必要があります。

use Carbon\Carbon;

現在時刻を取得する

now()メソッドで現在の日時を取得できます。パラメータを指定しない場合、PHP 設定のタイムゾーンが使用されます:

<?php
echo Carbon::now(); //2016-10-14 20:21:20
?>

別のタイムゾーンを使用したい場合は、有効なタイムゾーンをパラメータとして渡す必要があります:

// 直接使用字符串
echo Carbon::now(&#39;Europe/London&#39;); //2016-10-14 20:21:20
// 或者
echo Carbon::now(new DateTimeZone(&#39;Europe/London&#39;));

now() さらに、today() tomorrow()yesterday() などの静的関数は、ただし、時刻はすべて 00 :00:00: now() 外,还提供了 today() tomorrow()yesterday() 等静态函数,不过,它们的时间都是 00:00:00 :

echo Carbon::now();        // 2016-10-14 15:18:34
echo Carbon::today();       // 2016-10-14 00:00:00
echo Carbon::tomorrow(&#39;Europe/London&#39;);       // 2016-10-14 00:00:00
echo Carbon::yesterday();       // 2016-10-14 00:00:00

以上输出结果其实是一个 Carbon 类型的日期时间对象:

Carbon {#179 ▼
 +"date": "2016-06-14 00:00:00.000000"
 +"timezone_type": 3
 +"timezone": "UTC"
}

要想获取字符串类型的日期,可以使用下面的代码:

echo Carbon::today()->toDateTimeString();
echo Carbon::yesterday()->toDateTimeString();
echo Carbon::tomorrow()->toDateTimeString();

日期类型转为字符串

如上所述,默认情况下,Carbon 的方法返回的为一个日期时间对象。虽然它是一个对象,但是你却可以直接使用 echo 输出结果,因为有 __toString 魔术方法。但是如果你想把它转为字符串,可以使用 toDateString 或 toDateTimeString 方法:

echo Carbon::now()->toDateString(); //2016-10-14
echo Carbon::now()->toDateTimeString(); //2016-10-14 20:22:50

日期解析

你还可以使用 parse 方法解析任何顺序和类型的日期(结果为 Carbon 类型的日期时间对象):

echo Carbon::parse(&#39;2016-10-15&#39;)->toDateTimeString(); //2016-10-15 00:00:00
echo Carbon::parse(&#39;2016-10-15&#39;)->toDateTimeString(); //2016-10-15 00:00:00
echo Carbon::parse(&#39;2016-10-15 00:10:25&#39;)->toDateTimeString(); //2016-10-15 00:10:25
 
echo Carbon::parse(&#39;today&#39;)->toDateTimeString(); //2016-10-15 00:00:00
echo Carbon::parse(&#39;yesterday&#39;)->toDateTimeString(); //2016-10-14 00:00:00
echo Carbon::parse(&#39;tomorrow&#39;)->toDateTimeString(); //2016-10-16 00:00:00
echo Carbon::parse(&#39;2 days ago&#39;)->toDateTimeString(); //2016-10-13 20:49:53
echo Carbon::parse(&#39;+3 days&#39;)->toDateTimeString(); //2016-10-18 20:49:53
echo Carbon::parse(&#39;+2 weeks&#39;)->toDateTimeString(); //2016-10-29 20:49:53
echo Carbon::parse(&#39;+4 months&#39;)->toDateTimeString(); //2017-02-15 20:49:53
echo Carbon::parse(&#39;-1 year&#39;)->toDateTimeString(); //2015-10-15 20:49:53
echo Carbon::parse(&#39;next wednesday&#39;)->toDateTimeString(); //2016-10-19 00:00:00
echo Carbon::parse(&#39;last friday&#39;)->toDateTimeString(); //2016-10-14 00:00:00

构造日期

你还可以使用单独的年月日来构造日期:

$year = &#39;2015&#39;;
$month = &#39;04&#39;;
$day = &#39;12&#39;;
 
echo Carbon::createFromDate($year, $month, $day); //2015-04-12 20:55:59
 
$hour = &#39;02&#39;;
$minute = &#39;15&#39;:
$second = &#39;30&#39;;
 
echo Carbon::create($year, $month, $day, $hour, $minute, $second); //2015-04-12 02:15:30
 
echo Carbon::createFromDate(null, 12, 25); // 年默认为当前年份

此外,还可以传递一个有效的时区作为最后一个参数。

日期操作

日期操作可以通过 add (增加)或 sub (减去)跟上要增加或减去的单位来完成。例如,你想给一个日期增加指定的天数,你可以使用 addDays 方法。此外还提供了一个 modify 方法,参数格式为 + 或 - 跟上值及单位。所以,如果你想给当前日期增加一年,你可以传递 +1 year:

echo Carbon::now()->addDays(25); //2016-11-09 14:00:01
echo Carbon::now()->addWeeks(3); //2016-11-05 14:00:01
echo Carbon::now()->addHours(25); //2016-10-16 15:00:01
echo Carbon::now()->subHours(2); //2016-10-15 12:00:01
echo Carbon::now()->addHours(2)->addMinutes(12); //2016-10-15 16:12:01
echo Carbon::now()->modify(&#39;+15 days&#39;); //2016-10-30 14:00:01
echo Carbon::now()->modify(&#39;-2 days&#39;); //2016-10-13 14:00:01

日期比较

在 Carbon 中你可以使用下面的方法来比较日期:

  • min –返回最小日期。

  • max – 返回最大日期。

  • eq – 判断两个日期是否相等。

  • gt – 判断第一个日期是否比第二个日期大。

  • lt – 判断第一个日期是否比第二个日期小。

  • gte – 判断第一个日期是否大于等于第二个日期。

  • lte – 判断第一个日期是否小于等于第二个日期。

echo Carbon::now()->tzName;            // America/Toronto
$first = Carbon::create(2012, 9, 5, 23, 26, 11);
$second = Carbon::create(2012, 9, 5, 20, 26, 11, &#39;America/Vancouver&#39;);
 
echo $first->toDateTimeString();          // 2012-09-05 23:26:11
echo $first->tzName;                // America/Toronto
echo $second->toDateTimeString();         // 2012-09-05 20:26:11
echo $second->tzName;               // America/Vancouver
 
var_dump($first->eq($second));           // bool(true)
var_dump($first->ne($second));           // bool(false)
var_dump($first->gt($second));           // bool(false)
var_dump($first->gte($second));          // bool(true)
var_dump($first->lt($second));           // bool(false)
var_dump($first->lte($second));          // bool(true)
 
$first->setDateTime(2012, 1, 1, 0, 0, 0);
$second->setDateTime(2012, 1, 1, 0, 0, 0);     // Remember tz is &#39;America/Vancouver&#39;
 
var_dump($first->eq($second));           // bool(false)
var_dump($first->ne($second));           // bool(true)
var_dump($first->gt($second));           // bool(false)
var_dump($first->gte($second));          // bool(false)
var_dump($first->lt($second));           // bool(true)
var_dump($first->lte($second));          // bool(true)

要判断一个日期是否介于两个日期之间,可以使用 between() 方法,第三个可选参数指定比较是否可以相等,默认为 true:

$first = Carbon::create(2012, 9, 5, 1);
$second = Carbon::create(2012, 9, 5, 5);
var_dump(Carbon::create(2012, 9, 5, 3)->between($first, $second));     // bool(true)
var_dump(Carbon::create(2012, 9, 5, 5)->between($first, $second));     // bool(true)
var_dump(Carbon::create(2012, 9, 5, 5)->between($first, $second, false));  // bool(false)

此外还提供了一些辅助方法,你可以从它们的名字中明白其含义:

$dt = Carbon::now();
 
$dt->isWeekday();
$dt->isWeekend();
$dt->isYesterday();
$dt->isToday();
$dt->isTomorrow();
$dt->isFuture();
$dt->isPast();
$dt->isLeapYear();
$dt->isSameDay(Carbon::now());
$born = Carbon::createFromDate(1987, 4, 23);
$noCake = Carbon::createFromDate(2014, 9, 26);
$yesCake = Carbon::createFromDate(2014, 4, 23);
$overTheHill = Carbon::now()->subYears(50);
var_dump($born->isBirthday($noCake));       // bool(false)
var_dump($born->isBirthday($yesCake));       // bool(true)
var_dump($overTheHill->isBirthday());       // bool(true) -> default compare it to today!

diffForHumans

“一个月前”比“30 天前”更便于阅读,很多日期库都提供了这个常见的功能,日期被解析后,有下面四种可能性:

1、当比较的时间超过当前默认时间

  • 1天前

  • 5月前

2、当用将来的时间与当前默认时间比较

  • 1小时距现在

  • 5月距现在

3、当比较的值超过另一个值

  • 1小时前

  • 5月前

4、当比较的值在另一个值之后

  • 1小时后

  • 5月后

你可以把第二个参数设置为 true 来删除“前”、“距现在”等修饰语:diffForHumans(Carbon $other, true)

echo Carbon::now()->subDays(5)->diffForHumans();        // 5天前
 
echo Carbon::now()->diffForHumans(Carbon::now()->subYear());  // 1年后
 
$dt = Carbon::createFromDate(2011, 8, 1);
 
echo $dt->diffForHumans($dt->copy()->addMonth());       // 1月前
echo $dt->diffForHumans($dt->copy()->subMonth());       // 11月后
 
echo Carbon::now()->addSeconds(5)->diffForHumans();      // 5秒距现在
 
echo Carbon::now()->subDays(24)->diffForHumans();       // 3周前
echo Carbon::now()->subDays(24)->diffForHumans(null, true);  // 3周

上記の出力結果は、実際には Carbon 型の日付と時刻オブジェクトです:

public function boot()
{
  \Carbon\Carbon::setLocale(&#39;zh&#39;);
}
文字列型の日付を取得するには、次のコードを使用できます。
$article->created_at->diffForHumans();

日付型を文字列に変換します🎜🎜🎜🎜🎜 上で述べたように、デフォルトでは、Carbon のメソッドは日付と時刻のオブジェクトを返します。オブジェクトではありますが、__toString マジックメソッドを使用しているため、直接 echo を使用して結果を出力できます。ただし、文字列に変換したい場合は、toDateString メソッドまたは toDateTimeString メソッドを使用できます。 Carbon 型 datetime オブジェクト ): 🎜rrreee🎜🎜 日付の構築 🎜🎜🎜🎜 別々の年、月、日を使用して日付を構築することもできます: 🎜rrreee🎜 さらに、最後の引数として有効なタイムゾーンを渡すこともできます。 🎜🎜🎜日付演算🎜🎜🎜🎜日付演算は、加算または減算する単位に合わせて加算(増加)または減算(減算)することで実行できます。たとえば、指定した日数を日付に追加する場合は、addDays メソッドを使用できます。さらに、パラメータの形式は + または - の後に値と単位が続きます。したがって、現在の日付に年を追加したい場合は、+1 年を渡すことができます: 🎜rrreee🎜🎜日付比較🎜🎜🎜🎜 Carbon では、次のメソッドを使用して日付を比較できます: 🎜
  • 🎜min – 最小の日付を返します。 🎜
  • 🎜max – 最大の日付を返します。 🎜
  • 🎜eq – 2 つの日付が等しいかどうかを判断します。 🎜
  • 🎜gt – 最初の日付が 2 番目の日付より大きいかどうかを判断します。 🎜
  • 🎜lt – 最初の日付が 2 番目の日付より小さいかどうかを判断します。 🎜
  • 🎜gte – 最初の日付が 2 番目の日付以上であるかどうかを判断します。 🎜
  • 🎜lte – 最初の日付が 2 番目の日付以下であるかどうかを判断します。 🎜
rrreee🎜 日付が 2 つの日付の間にあるかどうかを判断するには、behind() メソッドを使用して、比較が等しいかどうかを指定します: 🎜rrreee🎜。いくつかのヘルパー メソッドも提供されており、その名前から意味を理解できます。 🎜rrreee🎜🎜diffForHumans🎜🎜🎜🎜 「30 日前」より「1 か月前」の方が読みやすいです。多くの日付ライブラリがこの共通関数を提供しています。日付が解析された後は、次の 4 つの可能性があります: 🎜🎜1. 比較された時間が現在のデフォルト時間を超えている場合🎜🎜
  • 🎜 1 日前🎜
  • 🎜5 か月前🎜
🎜2. 現在のデフォルト時刻と将来の時刻を比較する場合🎜🎜
  • 🎜1 時間後今🎜
  • 🎜5 か月後🎜
🎜3. 比較された値が他の値を超えた場合🎜🎜
  • 🎜1 時間前🎜
  • 🎜5 ヶ月前🎜
🎜4. 比較される値が別の値より後である場合🎜🎜
  • 🎜1 時間後🎜
  • 🎜5 か月後🎜
🎜2 番目のパラメータを true に設定すると、「以前」、「これから」などを削除できます。修飾子: diffForHumans(Carbon $other, true) 。 🎜rrreee🎜🎜🎜ローカリゼーション🎜🎜🎜

可以在 app/Providers/AppServiceProvider.php 的 boot() 方法中添加下面的代码来设置全局本地化:

public function boot()
{
  \Carbon\Carbon::setLocale(&#39;zh&#39;);
}

设置好之后,在输出时间的地方调用:

$article->created_at->diffForHumans();

类似的格式即可。

更多 Carbon 操作,可查看文档。

以上がCarbon、Laravel の日時処理パッケージの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。