PHP中常见的格式化显示时间日期函数

time()函数

time() 函数返回当前时间的 Unix 时间戳。返回自从 Unix 纪元(格林威治时间 1970 年 1 月 1 日 00:00:00)到当前时间的秒数。

自 PHP 5.1 起在 $_SERVER['REQUEST_TIME'] 中保存了发起该请求时刻的时间戳。

 代码如下 复制代码

<?php
$time = time();
echo($time . "<br />");
echo(date("D F d Y", $time));
?>

程序运行结果:

1292984702 

Wed December 22 2010

1292984702单位是秒,从1970 年 1 月 1 日 00:00:00到现在的秒数。

有时候我们想知道下一周的今天的一些情况,比如是几号,星期几等等,我们可以这么写:

 代码如下 复制代码

<?php
$nextWeek = time() + (7 * 24 * 60 * 60); // 7 days; 24 hours; 60 mins; 60secs
echo 'Now:       '. date('Y-m-d') ."<br />";
echo 'Next Week: '. date('Y-m-d D', $nextWeek) ."<br />";
?>

程序运行结果:

Now: 2010-12-22 

Next Week: 2010-12-29 Wed

date()函数

这个函数就比较熟悉了。

 代码如下 复制代码

<?php
echo("Result with date():<br />");
echo(date("l") . "<br />");
echo(date("l dS of F Y h:i:s A") . "<br />");
echo("Oct 3,1975 was on a ".date("l", mktime(0,0,0,10,3,1975))."<br />");
echo(date(DATE_RFC822) . "<br />");
echo(date(DATE_ATOM,mktime(0,0,0,10,3,1975)) . "<br /><br />");

echo("Result with gmdate():<br />");
echo(gmdate("l") . "<br />");
echo(gmdate("l dS of F Y h:i:s A") . "<br />");
echo("Oct 3,1975 was on a ".gmdate("l", mktime(0,0,0,10,3,1975))."<br />");
echo(gmdate(DATE_RFC822) . "<br />");
echo(gmdate(DATE_ATOM,mktime(0,0,0,10,3,1975)) . "<br />");
?>

程序运行结果:

Result with date():
Wednesday
Wednesday 22nd of December 2010 02:36:18 AM
Oct 3,1975 was on a Friday
Wed, 22 Dec 10 02:36:18 +0000
1975-10-03T00:00:00+00:00

Result with gmdate():
Wednesday
Wednesday 22nd of December 2010 02:36:18 AM
Oct 3,1975 was on a Friday
Wed, 22 Dec 10 02:36:18 +0000
1975-10-03T00:00:00+00:00

所以,我们应该给一个兼容性的写法,统一使用gmdate,并手工设置当前时区,写法改进如下:

 代码如下 复制代码

echo gmdate('Y-m-d H:i:s', time() + 3600 * 8);

这样不管在Linux+Apache下还是Windows下都得到了正确的结果,当然这样写还有一个好处,当网站是面向全世界的时候,那么网站用户只要设置所在的时区,程序自动根据用户设置的时区进行时间计算,数据库中信息发布时间只存当前的time()所生成的时间,那么在中国+8时区看到的发布时间是:2007-03-14 12:15:27,那么在欧洲+2时区用户看到这个信息的发布时间是:2007-03-14 06:15:27,这样信息的时间就全部对应正确了。

一个用于社区的自定格式显示日期

 代码如下 复制代码

/**
* 格式化显示时间函数
*
* 类似豆瓣(几秒前/几分前/今天3:50/昨天3:50/3-6)
*
* @param $timestamp 时间戳 必选参数,后面三个参数可选,为提高计算速度,建议直接赋值
* @param $now 当前时间戳
* @param $today 今天00:00时间戳
* @param $yesterday 昨天00:00时间戳
* @return string
*/
function timeshow($timestamp,$now=0,$today=0,$yesterday = 0){
if(! $timestamp){return '';}
if(! $now){$now = time();}
if(! $today){$today = strtotime("today");}
if(! $yesterday){$yesterday = $today-86400;}
$cha = $now-$timestamp;
if($cha<60){
return $cha."秒前";
}elseif($cha<60*60){
$min = floor($cha/60);
return $min."分钟前";
}elseif($timestamp>=$today){
return date("今天H:i",$timestamp);
}elseif($timestamp>=$yesterday){
return date("昨天H:i",$timestamp);
}else{
return date("m-d",$timestamp);
}
}

文章最后给大家介绍一些参数

格式化方式 说明
Y 4位数字年,y为2位数字,如99即1999年
m 数字月份,前面有前导0,如01。n 为无前导0数字月份
F 月份,完整的文本格式,例如 January 或者 March
M 三个字母缩写表示的月份,例如 Jan 或者 Mar
d 月份中的第几天,前面有前导0,如03。j 为无前导0的天数
w 星期中的第几天,以数字表示,0表示星期天
z 年份中的第几天,范围0-366
W 年份中的第几周,如第32周
H 24小时格式,有前导0,h为12小时格式
G 24小时格式,无前导0,g为对应12小时格式
i 分钟格式,有前导0
s 秒格式,有前导0
A 大写上下午,如AM,a为小写

可选参数 timestamp 表示时间戳,默认为 time() ,即当前时间戳。

时间: 2024-10-24 22:28:16

PHP中常见的格式化显示时间日期函数的相关文章

在ASP中按指定参数格式化显示时间的函数。

函数|显示|函数 <%'该函数作用:按指定参数格式化显示时间.'numformat=1:将时间转化为yyyy-mm-dd hh:nn格式.'numformat=2:将时间转化为yyyy-mm-dd格式.'numformat=3:将时间转化为hh:nn格式.'numformat=4:将时间转化为yyyy年mm月dd日 hh时nn分格式.'numformat=5:将时间转化为yyyy年mm月dd日格式.'numformat=6:将时间转化为hh时nn分格式.'numformat=7:将时间转化为yy

在ASP中按指定参数格式化显示时间的函数

函数|显示|函数 <%'该函数作用:按指定参数格式化显示时间.'numformat=1:将时间转化为yyyy-mm-dd hh:nn格式.'numformat=2:将时间转化为yyyy-mm-dd格式.'numformat=3:将时间转化为hh:nn格式.'numformat=4:将时间转化为yyyy年mm月dd日 hh时nn分格式.'numformat=5:将时间转化为yyyy年mm月dd日格式.'numformat=6:将时间转化为hh时nn分格式.'numformat=7:将时间转化为yy

ASP按指定参数格式化显示时间的函数

Date 函数 描述:返回当前系统日期. 语法:Date DateAdd 函数 描述:返回已添加指定时间间隔的日期. 语法:DateAdd(interval, number, date) interval: 必选.字符串表达式,表示要添加的时间间隔.有关数值,请参阅"设置"部分. number: 必选.数值表达式,表示要添加的时间间隔的个数.数值表达式可以是正数(得到未来的日期)或负数(得到过去的日期). date: 必选.Variant 或要添加 interval 的表示日期的文字.

浅析GridView中显示时间日期格式的问题_实用技巧

以下都是GridView基本常用的日期,时间格式 形式 语法 结果 注释 数字 {0:N2} 12.36   数字 {0:N0} 13   货币 {0:c2} $12.36   货币 {0:c4} $12.3656   货币 "¥{0:N2}" ¥12.36   科学计数法 {0:E3} 1.23E+001   百分数 {0:P} 12.25% P and p present the same. 日期 {0:D} 2006年11月25日   日期 {0:d} 2006-11-25  

PostgreSQL的时间日期函数用法介绍

一.获取系统时间函数 1.1 获取当前完整时间  代码如下 复制代码 select now(); david=# select now();               now              -------------------------------  2013-04-12 15:39:40.399711+08 (1 row) david=# current_timestamp 同 now() 函数等效. david=# select current_timestamp;    

js 常用时间日期函数

// js 常用时间日期函数 function load(){  var time = new Date( ); //获得当前时间  var year = time.getFullYear();   //获得年  var month = (time.getMonth()+1);   //获得月份 0-11  if(month<10){   month = '0' + month;  }  var ri = time.getDate();       //获得日期 1-31  if(ri<10)

js 格式化时间日期函数小结_时间日期

复制代码 代码如下: Date.prototype.format = function(format){ var o = { "M+" : this.getMonth()+1, //month "d+" : this.getDate(), //day "h+" : this.getHours(), //hour "m+" : this.getMinutes(), //minute "s+" : this.g

javascript 格式化时间日期函数代码脚本之家修正版_时间日期

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] javascript格式化日期时间函数_时间日期_http://www.jb51.net/article/14753.htm

sql时间日期函数使用说明

1.dateadd  加日期函数 select dateadd(day,2,'2004-10-15')  --返回:2004-10-17 00:00:00.000 当然也可以加月份     select dateadd(month,2,'2004-10-15') 2.datediff 返回两个日期之间日期  select datediff(day,'2004-09-01','2004-09-18')   --返回:17  和dateadd  一样,day也可以换成别的 3.datepart 返回