-
php常用日期时间函数实例小结
这篇文章主要介绍了php常用日期时间函数,结合实例形式总结分析了php日期时间相关的时间戳、格式化、时区获取与设置、时间戳转换与计算等相关操作技巧,需要的朋友可以参考下。
本文实例讲述了php常用日期时间函数,分享给大家供大家参考,具体如下:
时间戳
时间戳我就不赘述了,手册里有,就是能精确的表示一个时间点,我在做项目的时候经常用时间戳来表示数据,这样比较方便,如果保存为日期时间型的数据,显示的时候可能比较省事,但是如果是获取这个日期的某个年份或月份,就比较麻烦了。
- <?php
- echo time();//返回一个以秒为单位的时间戳 :1467968841
- echo microtime(true);//返回一个以毫秒为单位的时间戳 :1467968841.4155
- echo microtime();//返回带毫秒和秒的时间戳 :0.41553000 1467968841,前面是毫秒小数,后面是秒数
- ?>
时间戳格式化
1、date($format,$timestamp):在当前使用的时区下格式化时间戳
2、gmdate($format,$timestamp):指定UTC时区下格式化时间戳,不论用户使用什么时区
时区的概念:时区是按照地点设置的时间,中国属于东8区,所以比UTC(格林尼治时间)要快8个小时
获取和设置时区
date_default_timezone_get()//获得当前使用的时区,默认情况下应该是UTC
date_default_timezone_set(‘Asia/Shanghai')//设置当前的时区为亚洲上海
- <?php
- echo date("Y-m-d 星期N H:i:s a",$time);//2016-07-08 星期5 10:44:26 am(默认时区下)
- echo date("Y-m-d 星期N H:i:s a",0);//1970-01-01 星期4 00:00:00(默认时区下)
- echo gmdate("Y-m-d 星期N H:i:s a",0);//1970-01-01 星期4 00:00:00(全部在UTC时区下)
- ?>
解析时间格式变为时间戳
1、mktime():将制定的时间格式解析成时间戳
- <?php
- echo mktime(19,15,0,7,8,2016);//获取2016年8月7日19时15分0秒的时间戳
- ?>
2、strtotime():将任何英文文本的日期时间描述解析为时间戳
- <?php
- echo strtotime("2016-7-8 19:15:0");//获取2016年8月7日19时15分0秒的时间戳
- echo strtotime("now");//获取现在得时间戳
- echo strtotime("+1 day");//当前时间往后推一天的时间戳
- echo strtotime("-1 day");//当前时间往前推一天的时间戳
- ?>
3、checkdate():检测输入的日期是否存在
- <?php
- var_dump(checkdate(2,29,2015));//2015年2月29日不存在,所以是false
- var_dump(checkdate(2,29,2016));//2016年2月29日存在,所以是true
- ?>
案例:计算两个日期的日期差数
1、用时间戳来计算
- <?php
- $day1 = "2016-7-8";
- $day2 = "2016-7-1";
- echo (strtotime($day1) - strtotime($day2))/(24 * 60 * 60);
- ?>
2、用DateTime类来计算
- <?php
- $datetime1 = new DateTime('2016-7-8');
- $datetime2 = new DateTime('2016-7-1');
- $interval = $datetime2->diff($datetime1);
- echo $interval->format('%R%a days');
- ?>
出处:http://www.phpfensi.com/php/20211201/18912.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式