laravel常用程式碼庫:Carbon日期及時間處理包-年月日操作完整版常用方法以及使用場景

wangchunbo發表於2020-12-23

隨著資訊科技進步,我們發現時間戳並不滿足我們的要求。
日期時間會更多的被設計在資料庫欄位中。
並且前端元件傳遞的也是datetime方便。

官網地址:carbon.nesbot.com/

安裝

透過 Composer 來安裝 Carbon:

composer require nesbot/carbon

PS:由於 Laravel 專案已預設安裝了此包,所以不需要再次執行上面的命令。

使用

你需要透過名稱空間匯入 Carbon 來使用,而不需每次都提供完整的名稱。

use Carbon\Carbon;

獲取當前時間

可以同now() 方法獲取當前的日期和時間。如果你不指定引數,它會使用 PHP 配置中的時區:

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

如果你想使用一個不同的時區,你需要傳遞一個有效的時區作為引數:
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();

日期型別轉為字串

如上所述,預設情況下,Carbon 的方法返回的為一個日期時間物件。雖然它是一個物件,但是你卻可以直接使用 echo 輸出結果,因為有 __toString魔術方法。但是如果你想把它轉為字串,可以使用 toDateStringtoDateTimeString 方法:

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

日期解析

你還可以使用 parse方法解析任何順序和型別的日期(結果為 Carbon 型別的日期時間物件):

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

構造日期

你還可以使用單獨的年月日來構造日期:

$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);  // 年預設為當前年份

此外,還可以傳遞一個有效的時區作為最後一個引數。

使用場景: 指定查詢某日期的資料,比如說,世界盃,就是指定一個年份。然後迴圈去查詢歷屆世界盃。

日期操作

日期操作可以透過 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('+15 days'); //2016-10-30 14:00:01
echo Carbon::now()->modify('-2 days'); //2016-10-13 14:00:01

使用場景: 首頁預設的一些熱門資料,我們只查詢出7天內,或者15天內的資料。

日期比較

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, '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)

要判斷一個日期是否介於兩個日期之間,可以使用 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天前
    • 5月前
  • 當用將來的時間與當前預設時間比較

    • 1小時距現在
    • 5月距現在
  • 當比較的值超過另一個值

    • 1小時前
    • 5月前
  • 當比較的值在另一個值之後

    • 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::parse($follow_up_year_month)->firstOfMonth();

傳入日期的月份最後一天


Carbon::parse($follow_up_year_month)->lastOfMonth();

ps:如果獲取當月的。你前面改為:

Carbon::now()->lastOfMonth();

使用場景:日曆查詢資料,統計資料。

參考文章

carbon.nesbot.com/#reference

本作品採用《CC 協議》,轉載必須註明作者和本文連結
感謝關注 上海PHP自學中心-免費程式設計影片教學|

相關文章