说明
返回将整数timestamp按照给定的格式字串而产生的字符串。如果没有给出时间戳则使用本地当前时间。换句话说,timestamp是可选的,默认值为time()。
提示:自 PHP 5.1.0 起有几个有用的常量可用作标准的日期/时间格式来指定format参数。
提示:自 PHP 5.1 起在$_SERVER['REQUEST_TIME']中保存了发起该请求时刻的时间戳。
注意:有效的时间戳典型范围是格林威治时间 1901 年 12 月 13 日 20:45:54 到 2038 年 1 月 19 日 03:14:07。(此范围符合
32 位有符号整数的最小值和最大值)。不过在 PHP 5.1 之前此范围在某些系统(如 Windows)中限制为从 1970 年 1 月 1 日到 2038 年
1 月 19 日。
| format字符 | 说明 | 返回值例子 |
|---|
| 日 | --- | --- |
d | 月份中的第几天,有前导零的 2 位数字 | 01到31 |
D | 星期中的第几天,文本表示,3 个字母 | Mon到Sun |
j | 月份中的第几天,没有前导零 | 1到31 |
l(“L”的小写字母) | 星期几,完整的文本格式 | Sunday到Saturday |
N | ISO-8601 格式数字表示的星期中的第几天(PHP 5.1.0 新加) | 1(表示星期一)到7(表示星期天) |
S | 每月天数后面的英文后缀,2 个字符 | st,nd,rd或者th。可以和j一起用 |
w | 星期中的第几天,数字表示 | 0(表示星期天)到6(表示星期六) |
z | 年份中的第几天 | 0到366 |
| 星期 | --- | --- |
W | ISO-8601 格式年份中的第几周,每周从星期一开始(PHP 4.1.0 新加的) | 例如:42(当年的第 42 周) |
| 月 | --- | --- |
F | 月份,完整的文本格式,例如 January 或者 March | January到December |
m | 数字表示的月份,有前导零 | 01到12 |
M | 三个字母缩写表示的月份 | Jan到Dec |
n | 数字表示的月份,没有前导零 | 1到12 |
t | 给定月份所应有的天数 | 28到31 |
| 年 | --- | --- |
L | 是否为闰年 | 如果是闰年为1,否则为0 |
o | ISO-8601 格式年份数字。这和Y的值相同,只除了如果 ISO 的星期数(W)属于前一年或下一年,则用那一年。(PHP 5.1.0 新加) | Examples:1999or2003 |
Y | 4 位数字完整表示的年份 | 例如:1999或2003 |
y | 2 位数字表示的年份 | 例如:99或03 |
| 时间 | --- | --- |
a | 小写的上午和下午值 | am或pm |
A | 大写的上午和下午值 | AM或PM |
B | Swatch Internet 标准时 | 000到999 |
g | 小时,12 小时格式,没有前导零 | 1到12 |
G | 小时,24 小时格式,没有前导零 | 0到23 |
h | 小时,12 小时格式,有前导零 | 01到12 |
H | 小时,24 小时格式,有前导零 | 00到23 |
i | 有前导零的分钟数 | 00到59> |
s | 秒数,有前导零 | 00到59> |
| 时区 | --- | --- |
e | 时区标识(PHP 5.1.0 新加) | 例如:UTC,GMT,Atlantic/Azores |
I | 是否为夏令时 | 如果是夏令时为1,否则为0 |
O | 与格林威治时间相差的小时数 | 例如:+0200 |
T | 本机所在的时区 | 例如:EST,MDT(【译者注】在
Windows 下为完整文本格式,例如“Eastern Standard Time”,中文版会显示“中国标准时间”)。 |
Z | 时差偏移量的秒数。UTC 西边的时区偏移量总是负的,UTC 东边的时区偏移量总是正的。 | -43200到43200 |
| 完整的日期/时间 | --- | --- |
c | ISO 8601 格式的日期(PHP 5 新加) | 2004-02-12T15:19:21+00:00 |
r | RFC 822 格式的日期 | 例如:Thu, 21 Dec 2000 16:01:07 +0200 |
U | 从 Unix 纪元(January 1 1970 00:00:00 GMT)开始至今的秒数 | 参见time() |
格式字串中不能被识别的字符将原样显示。Z格式在使用gmdate()时总是返回0。
<?php
//
设定要用的默认时区。
//自
PHP 5.1 可用
date_default_timezone_set('UTC');
//
输出类似:Monday
echodate("l");
//
输出类似:Monday 15th of
August 2005 03:12:46 PM
echodate('l dS \of F Y h:i:s A');
//
输出:July 1, 2000 is on a
Saturday
echo"July 1, 2000 is on a ".date("l",mktime(0,0,0,7,1,2000));
/*
在格式参数中使用常量
*/
// 输出类似:Mon, 15 Aug
2005 15:12:46 UTC
echodate(DATE_RFC822);
//
输出类似:2000-07-01T00:00:00+0000
echodate(DATE_ATOM,mktime(0,0,0,7,1,2000));
?>
在格式字串中的字符前加上反斜线来转义可以避免它被按照上表解释。如果加上反斜线后的字符本身就是一个特殊序列,那还要转义反斜线。
<?php
// prints
something like: Wednesday the 15th
echodate("l \\t\h\e
jS");
?>
可以把date()和mktime()结合使用来得到未来或过去的日期。
<?php
$tomorrow =mktime(0,0,0,date("m") ,date("d")+1,date("Y"));
$lastmonth=mktime(0,0,0,date("m")-1,date("d"), date("Y"));
$nextyear
=mktime(0,0,0,date("m"), date("d"), date("Y")+1);
?>
注意:由于夏令时的缘故,这种方法比简单地在时间戳上加减一天或者一个月的秒数更可靠。
一些使用date()格式化日期的例子。注意要转义所有其它的字符,因为目前有特殊含义的字符会产生不需要的结果,而其余字符在 PHP
将来的版本中可能会被用上。当转义时,注意用单引号以避免类似 \n 的字符变成了换行符。
<?php
//
假定今天是:March
10th, 2001, 5:16:18 pm
$today=date("F j, Y, g:i a");
// March 10, 2001, 5:16
pm
$today=date("m.d.y"); // 03.10.01
$today=date("j, n, Y");
// 10, 3, 2001
$today=date("Ymd");
// 20010310
$today=date('h-i-s, j-m-y, it is w Day z '); // 05-16-17,
10-03-01, 1631 1618 6 Fripm01
$today=date('\i\t \i\s \t\h\e jS \d\a\y.'); // It is the
10th day.
$today=date("D M j G:i:s T
Y"); // Sat Mar 10 15:16:08 MST 2001
$today=date('H:m:s \m \i\s\ \m\o\n\t\h'); // 17:03:17 m
is month
$today=date("H:i:s"); // 17:16:17
?>
要格式化其它语种的日期,应该用setlocale()和strftime()函数来代替date()。