Laravel中日期时间处理包Carbon的简单使用
前言
我们大家在编写 php 应用时经常需要处理日期和时间,这篇文章带你了解一下 carbon – 继承自 php datetime 类的 api 扩展,它使得处理日期和时间更加简单。
laravel 中默认使用的时间处理类就是 carbon。
<?php namespace carbon; class carbon extends \datetime { // code here }
你可以在 carbon 命名空间的 carbon 类中看到上面声明的代码片段。
安装
可以通过 composer 来安装 carbon:
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('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();
日期类型转为字符串
如上所述,默认情况下,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
日期比较
在 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、当比较的时间超过当前默认时间
- 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周
本地化
可以在 app/providers/appserviceprovider.php 的 boot()
方法中添加下面的代码来设置全局本地化:
public function boot() { \carbon\carbon::setlocale('zh'); }
设置好之后,在输出时间的地方调用:
$article->created_at->diffforhumans();
类似的格式即可。
更多 carbon 操作,可。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
推荐阅读
-
Java日期时间API系列11-----Jdk8中java.time包中的新的日期时间API类,使用java8日期时间API重写农历LunarDate
-
Java日期时间API系列30-----Jdk8中java.time包中的新的日期时间API类,减少时间精度方法性能比较和使用。
-
使用DateTimeOffset 对xml中的日期时间格式时区进行处理
-
Laravel中日期时间处理包Carbon的简单使用
-
Java日期时间API系列11-----Jdk8中java.time包中的新的日期时间API类,使用java8日期时间API重写农历LunarDate
-
Java日期时间API系列30-----Jdk8中java.time包中的新的日期时间API类,减少时间精度方法性能比较和使用。
-
分享PHP中的日期时间处理利器(Carbon)实例
-
Laravel中如何使用日期时间处理包Carbon的实例
-
分享PHP中的日期时间处理利器(Carbon)实例
-
Laravel中日期时间处理包Carbon