php日期时间函数

时间:2021-09-22 22:12:19

checkdate

验证日期的正确性。

语法: int checkdate(int month, int day, int year);

返回值: 整数

函数种类: 时间日期

内容说明

若日期是有效的则返回 true,若日期有问题,则返回 false。本函数可以用来检查日期是否有效。有效范围如下:

年 为 0 至 32767 年
月 为 1 至 12 月
日 则随着月份及闰年变化


1,年-月-日
echo date('Y-m-j');
2007-02-6

echo date('y-n-j');
07-2-6

大写Y表示年四位数字,而小写y表示年的两位数字;
小写m表示月份的数字(带前导),而小写n则表示不带前导的月份数字。

echo date('Y-M-j');
2007-Feb-6

echo date('Y-m-d');
2007-02-06

大写M表示月份的3个缩写字符,而小写m则表示月份的数字(带前导0);
没有大写的J,只有小写j表示月份的日期,无前导o;若需要月份带前导则使用小写d。

echo date('Y-M-j');
2007-Feb-6

echo date('Y-F-jS');
2007-February-6th

大写M表示月份的3个缩写字符,而大写F表示月份的英文全写。(没有小写f)
大写S表示日期的后缀,比如“st”、“nd”、“rd”和“th”,具体看日期数字为何。

小结:
表示年可以用大写的Y和小写y;
表示月可以用大写F、大写M、小写m和小写n(分别表示字符和数字的两种方式);
表示日可以用小写d和小写j,大写S表示日期的后缀。


2,时:分:秒

默认情况下,PHP解释显示的时间为“格林威治标准时间”,与我们本地的时间相差8个小时。

echo date('g:i:s a');
5:56:57 am

echo date('h:i:s A');
05:56:57 AM

小写g表示12小时制,无前导0,而小写h则表示有前导0的12小时制。
当使用12小时制时需要表明上下午,小写a表示小写的“am”和“pm”,大写A表示大写的“AM”和“PM”。

echo date('G:i:s');
14:02:26

大写G表示24小时制的小时数,但是不带前导的;使用大写的H表示带前导的24小时制小时数

小结:
字母g表示小时不带前导,字母h表示小时带前导;
小写g、h表示12小时制,大写G、H表示24小时制。

3,闰年、星期、天

echo date('L');
今年是否闰年:0

echo date('l');
今天是:Tuesday

echo date('D');
今天是:Tue

大写L表示判断今年是否闰年,布尔值,为真返回1,否则为0;
小写l表示当天是星期几的英文全写(Tuesday);
而使用大写D表示星期几的3个字符缩写(Tue)。

echo date('w');
今天星期:2

echo date('W');
本周是全年中的第 06 周

小写w表示星期几,数字形式表示
大写W表示一年中的星期数

echo date('t');
本月是 28 天

echo date('z');
今天是今年的第 36 天

小写t表示当前月份又多少天
小写z表示今天是本年中第几天

4,其他

echo date('T');
UTC
大写T表示服务器的时间区域设置

echo date('I');
0
大写I表示判断当前是否为夏令时,为真返回1,否则为0

echo date('U');
1170769424
大写U表示从1970年1月1日到现在的总秒数,就是Unix时间纪元的UNIX时间戳。

echo date('c');
2007-02-06T14:24:43+00:00
小写c表示ISO8601日期,日期格式为YYYY-MM-DD,用字母T来间隔日期和时间,时间格式为HH:MM:SS,时区使用格林威治标准时间(GMT)的偏差来表示。

echo date('r');
Tue, 06 Feb 2007 14:25:52 +0000
小写r表示RFC822日期。


-=------------------------------------------------------------------------------------------------------------
strftime

将服务器的时间本地格式化。

语法: string strftime(string format, int [timestamp]);

返回值: 字符串

函数种类: 时间日期

内容说明

返回值的字符串依配置的格式来决定。若有传入时间戳记值,则将时间戳记格式化返回;若无传入时间戳记值,则将目前服务器的时间本地格式化返回。月份或者星期名称随着本地语系配置 setlocale() 的不同而改变。

返回的字符串可以依下列的格式而定:

    * %a 星期几的缩写。
    * %A 星期几的全名。
    * %b 月份名称的缩写。
    * %B 月份名称的全名。
    * %c 本地端日期时间较佳表示字符串。
    * %d 用数字表示本月的第几天 (范围为 00 至 31)。
    * %H 用 24 小时制数字表示小时数 (范围为 00 至 23)。
    * %I 用 12 小时制数字表示小时数 (范围为 01 至 12)。
    * %j 以数字表示当年度的第几天 (范围为 001 至 366)。
    * %m 月份的数字 (范围由 1 至 12)。
    * %M 分钟。
    * %p 以 'AM' 或 'PM' 表示本地端时间。
    * %S 秒数。
    * %U 数字表示为本年度的第几周,第一个星期由第一个周日开始。
    * %W 数字表示为本年度的第几周,第一个星期由第一个周一开始。
    * %w 用数字表示本周的第几天 ( 0 为周日)。
    * %x 不含时间的日期表示法。
    * %X 不含日期的时间表示法。
    * %y 二位数字表示年份 (范围由 00 至 99)。
    * %Y 完整的年份数字表示,即四位数。
    * %Z 时区或名称缩写。
    * %% % 字符。

使用范例

<?php
setlocale ("LC_TIME", "C");
print(strftime("%A in Finnish is "));
setlocale ("LC_TIME", "fi");
print(strftime("%A, in French "));
setlocale ("LC_TIME", "fr");
print(strftime("%A and in German "));
setlocale ("LC_TIME", "de");
print(strftime("%A.\n"));
?>

date

将服务器的时间格式化。

语法: string date(string format, int [timestamp]);

返回值: 字符串

函数种类: 时间日期

内容说明

返回值的字符串依配置的格式来决定。若有传入时间戳记值,则将时间戳记格式化返回;若无传入时间戳记值,则将目前服务器的时间格式化返回。要将日期转为其它的语系格式,应使用setlocale() 及 strftime() 二个函数。字符串格式化的选项如下:

    * a - "am" 或是 "pm"
    * A - "AM" 或是 "PM"
    * d - 几日,二位数字,若不足二位则前面补零; 如: "01" 至 "31"
    * D - 星期几,三个英文字母; 如: "Fri"
    * F - 月份,英文全名; 如: "January"
    * h - 12 小时制的小时; 如: "01" 至 "12"
    * H - 24 小时制的小时; 如: "00" 至 "23"
    * g - 12 小时制的小时,不足二位不补零; 如: "1" 至 12"
    * G - 24 小时制的小时,不足二位不补零; 如: "0" 至 "23"
    * i - 分钟; 如: "00" 至 "59"
    * j - 几日,二位数字,若不足二位不补零; 如: "1" 至 "31"
    * l - 星期几,英文全名; 如: "Friday"
    * m - 月份,二位数字,若不足二位则在前面补零; 如: "01" 至 "12"
    * n - 月份,二位数字,若不足二位则不补零; 如: "1" 至 "12"
    * M - 月份,三个英文字母; 如: "Jan"
    * s - 秒; 如: "00" 至 "59"
    * S - 字尾加英文序数,二个英文字母; 如: "th","nd"
    * t - 指定月份的天数; 如: "28" 至 "31"
    * U - 总秒数
    * w - 数字型的星期几,如: "0" (星期日) 至 "6" (星期六)
    * Y - 年,四位数字; 如: "1999"
    * y - 年,二位数字; 如: "99"
    * z - 一年中的第几天; 如: "0" 至 "365"

其它不在上列的字符则直接列出该字符。

使用范例

范例一:
<?
print(date( "l dS of F Y h:i:s A" ));
print("July 1, 2000 is on a " . date("l", mktime(0,0,0,7,1,2000)));
?>

范例二:
<?
$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);
?>

getdate

获得时间及日期信息。

语法: array getdate(int timestamp);

返回值: 数组

函数种类: 时间日期

内容说明

返回数组的元素包括下列的项目:

    * "seconds" - 秒
    * "minutes" - 分
    * "hours" - 时
    * "mday" - 当月的第几天
    * "wday" - 当周的第几天数字
    * "mon" - 月份数字
    * "year" - 年,数字
    * "yday" - 当年的第几天数字; 如: "299"
    * "weekday" - 星期几全名; 如: "Friday"
    * "month" - 月份全名; 如: "January"