Laravelにおける日時処理パッケージCarbonの利用について

不言
リリース: 2023-03-31 21:54:01
オリジナル
2051 人が閲覧しました

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

まえがき

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

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

<?php
namespace Carbon;
 
class Carbon extends \DateTime
{
 // code here
}
ログイン後にコピー

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

#インストール

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

#
composer require nesbot/carbon
ログイン後にコピー

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

使用方法
Carbon を使用するには、毎回フルネームを指定せずに、名前空間を介して 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:

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();
ログイン後にコピー

#Convert date type to string

上で述べたように、デフォルトでは、Carbon のメソッドは日付と時刻のオブジェクトを返します。オブジェクトではありますが、__toString マジックメソッドを使用しているため、直接 echo を使用して結果を出力できます。ただし、文字列に変換する場合は、toDateString メソッドまたは toDateTimeString メソッドを使用できます。

echo Carbon::now()->toDateString(); //2016-10-14
echo Carbon::now()->toDateTimeString(); //2016-10-14 20:22:50
ログイン後にコピー

Date parsing

parse メソッドを使用して、任意の順序と型の日付を解析することもできます (結果は Carbon 型の datetime オブジェクトになります)。 # 日付の作成

#別々の年、月、日を使用して日付を作成することもできます:

#
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
ログイン後にコピー

また、最後の引数として有効なタイムゾーンを渡すこともできます。
日付操作

日付操作は、加算 (増加) または減算 (減算) の後に、加算または減算する単位を指定することによって実行できます。たとえば、指定した日数を日付に追加する場合は、addDays メソッドを使用できます。さらに、パラメータの形式は or - の後に値と単位が続きます。したがって、現在の日付に年を追加したい場合は、1 年を渡すことができます:

$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); // 年默认为当前年份
ログイン後にコピー

日付比較

Carbon では、次のメソッドを使用して日付を比較できます。

min – 最小の日付を返します。

max – 最大の日付を返します。

eq – 2 つの日付が等しいかどうかを判断します。
  • gt – 最初の日付が 2 番目の日付より大きいかどうかを判断します。
  • lt – 最初の日付が 2 番目の日付より小さいかどうかを判断します。
  • gte – 最初の日付が 2 番目の日付以上であるかどうかを判断します。
  • lte – 最初の日付が 2 番目の日付以下であるかどうかを判断します。
  • 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
    ログイン後にコピー
  • 日付が 2 つの日付の間にあるかどうかを判断するには、 between() メソッドを使用できます。3 番目のメソッドはオプションです。このパラメーターは、比較が等しいかどうかを指定します。デフォルトは true です:
  • 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)
    ログイン後にコピー

さらに、いくつかの補助メソッドが提供されており、その意味を理解することができます。彼らの名前:

$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)
ログイン後にコピー

diffForHumans

「30 か月前」より「1 か月前」の方が読みやすい多くの場合、日付ライブラリはこの一般的な機能を提供します。日付が解析された後は、次の 4 つの可能性があります:

##1。比較された時間が現在のデフォルト時間を超える場合

#1 日前


5 か月前

2. 将来の時刻と現在のデフォルト時刻を比較する場合

  • 今から 1 時間後

  • #今から 5 か月後

#3.比較された値が他の A 値を超えています

  • 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周
ログイン後にコピー

本地化

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

public function boot()
{
  \Carbon\Carbon::setLocale(&#39;zh&#39;);
}
ログイン後にコピー

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

$article->created_at->diffForHumans();
ログイン後にコピー

类似的格式即可。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

如何解决PHP基于DateTime类Unix时间戳与日期互转的问题

关于laravel 5.1下php artisan migrate的使用

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

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート