
Carbon 是 DateTime 的簡單 PHP API 擴充
随着資訊技術進步,我們發現時間戳并不滿足我們的要求。
日期時間會更多的被設計在資料庫字段中。
并且前端元件傳遞的也是 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
魔術方法。但是如果你想把它轉為字元串,可以使用
toDateString
或
toDateTimeString
方法:
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')->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周
使用場景: 快捷的算出幾小時,幾天内的資料。
月份的 第一天和 最後一天
傳入日期的月份第一天
傳入日期的月份最後一天
ps:如果擷取當月的。你前面改為:
Carbon::now()->lastOfMonth();
使用場景:月曆查詢資料,統計資料。
參考文章
carbon.nesbot.com/#reference