ホームページ >バックエンド開発 >PHPチュートリアル >Laravelにおける日時処理パッケージCarbonの利用について
日付の形式、タイムゾーン、閏年、日付が異なる月など、日付と時刻を処理する際には考慮すべき点がたくさんあります。次の記事で日付を中心に紹介します。 Laravel での時間処理については、Carbon の簡単な使い方が必要な方は参考にしてください。
まえがき
PHP アプリケーションを作成するときに、日付と時刻を扱う必要があることがよくあります。この記事では、Carbon について学びます。 from 継承 日付と時刻の操作を容易にする PHP DateTime クラスの API 拡張機能。
Laravel で使用されるデフォルトの時間処理クラスは Carbon です。
<?php namespace Carbon; class Carbon extends \DateTime { // code here }
Carbon 名前空間の Carbon クラスで上記で宣言されたコード スニペットを確認できます。
#インストール
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('Europe/London'); //2016-10-14 20:21:20 // 或者 echo Carbon::now(new DateTimeZone('Europe/London'));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('Europe/London'); // 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:50Date parsing
parse メソッドを使用して、任意の順序と型の日付を解析することもできます (結果は Carbon 型の datetime オブジェクトになります)。 # 日付の作成
echo Carbon::parse('2016-10-15')->toDateTimeString(); //2016-10-15 00:00:00 echo Carbon::parse('2016-10-15')->toDateTimeString(); //2016-10-15 00:00:00 echo Carbon::parse('2016-10-15 00:10:25')->toDateTimeString(); //2016-10-15 00:10:25 echo Carbon::parse('today')->toDateTimeString(); //2016-10-15 00:00:00 echo Carbon::parse('yesterday')->toDateTimeString(); //2016-10-14 00:00:00 echo Carbon::parse('tomorrow')->toDateTimeString(); //2016-10-16 00:00:00 echo Carbon::parse('2 days ago')->toDateTimeString(); //2016-10-13 20:49:53 echo Carbon::parse('+3 days')->toDateTimeString(); //2016-10-18 20:49:53 echo Carbon::parse('+2 weeks')->toDateTimeString(); //2016-10-29 20:49:53 echo Carbon::parse('+4 months')->toDateTimeString(); //2017-02-15 20:49:53 echo Carbon::parse('-1 year')->toDateTimeString(); //2015-10-15 20:49:53 echo Carbon::parse('next wednesday')->toDateTimeString(); //2016-10-19 00:00:00 echo Carbon::parse('last friday')->toDateTimeString(); //2016-10-14 00:00:00
また、最後の引数として有効なタイムゾーンを渡すこともできます。
日付操作
日付操作は、加算 (増加) または減算 (減算) の後に、加算または減算する単位を指定することによって実行できます。たとえば、指定した日数を日付に追加する場合は、addDays メソッドを使用できます。さらに、パラメータの形式は or - の後に値と単位が続きます。したがって、現在の日付に年を追加したい場合は、1 年を渡すことができます:
$year = '2015'; $month = '04'; $day = '12'; echo Carbon::createFromDate($year, $month, $day); //2015-04-12 20:55:59 $hour = '02'; $minute = '15': $second = '30'; echo Carbon::create($year, $month, $day, $hour, $minute, $second); //2015-04-12 02:15:30 echo Carbon::createFromDate(null, 12, 25); // 年默认为当前年份
日付比較
Carbon では、次のメソッドを使用して日付を比較できます。
min – 最小の日付を返します。
max – 最大の日付を返します。
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('+15 days'); //2016-10-30 14:00:01 echo Carbon::now()->modify('-2 days'); //2016-10-13 14:00:01
echo Carbon::now()->tzName; // America/Toronto $first = Carbon::create(2012, 9, 5, 23, 26, 11); $second = Carbon::create(2012, 9, 5, 20, 26, 11, 'America/Vancouver'); 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 'America/Vancouver' 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('zh'); }
设置好之后,在输出时间的地方调用:
$article->created_at->diffForHumans();
类似的格式即可。
以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!
相关推荐:
如何解决PHP基于DateTime类Unix时间戳与日期互转的问题
关于laravel 5.1下php artisan migrate的使用
以上がLaravelにおける日時処理パッケージCarbonの利用についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。