Maison > développement back-end > tutoriel php > fonction de date php et fonction d'heure php

fonction de date php et fonction d'heure php

不言
Libérer: 2023-03-29 11:22:02
original
3054 Les gens l'ont consulté

Cet article présente principalement la fonction de date PHP et la fonction d'heure PHP. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer

1 :
La fonction checkdate() vérifie une date. checkdate(month,day,year)
Si la valeur spécifiée est légale, cette fonction renvoie vrai, sinon elle renvoie faux.
La date est légale si :
le mois est compris entre 1 et 12 inclus.
La valeur du jour se situe dans la plage de jours qu'un mois donné devrait avoir, en tenant compte des années bissextiles.
l'année est comprise entre 1 et 32767 inclus.
Exemple 1 :

<?php
var_dump(checkdate(12,31,2000));//var_dump函数显示表达式的类型与值
var_dump(checkdate(2,29,2003));
var_dump(checkdate(2,29,2004));
?>
显示:
bool(true)
bool(false)
bool(true)
例子2:
<?php
if (checkdate(12,31,2009))
{
echo "a";
}
else
{
echo "b";
}
?>
Copier après la connexion
Affichage :

a
Copier après la connexion

date_default_timezone_set() fonction Définit le fuseau horaire par défaut pour toutes les fonctions de date/heure utilisées dans les scripts. date_default_timezone_set(timezone)
fuseau horaire requis. Identifiant de fuseau horaire, tel que « UTC » ou « Europe/Paris ».
Liste des fuseaux horaires légaux : http://www.php.net/manual/en/timezones.php
Exemple

<?php
echo(date_default_timezone_set("Europe/Paris"));
?>
Copier après la connexion
Affichage :

1
Copier après la connexion


date_default_timezone_get() La fonction renvoie le fuseau horaire par défaut utilisé par toutes les fonctions de date et d'heure dans le script. date_default_timezone_get(void)
void Facultatif

<?php
echo(date_default_timezone_get());
?>
Copier après la connexion
Affichage :

Asia/Shanghai
Copier après la connexion
Quatre :


time() Le La fonction renvoie l’horodatage Unix de l’heure actuelle. Renvoie le nombre de secondes écoulées depuis l'époque Unix (1er janvier 1970 00:00:00 GMT) jusqu'à l'heure actuelle.
Depuis PHP 5.1, l'horodatage de l'heure à laquelle la requête a été initiée est enregistré dans $_SERVER['REQUEST_TIME'].
Exemple :

<?php
$t=time();
echo($t . "<br />");
echo(date("D F d Y",$t));
?>
Copier après la connexion
1138618081//这是总秒数
Mon January 30 2006
Copier après la connexion
5 :


date() formate une heure/date locale. La fonction gmdate() formate la date/heure GMT/UTC. Similaire à la fonction date(), sauf que l'heure renvoyée est l'heure moyenne de Greenwich (GMT).
date(format,timestamp)
le format doit spécifier comment renvoyer le résultat
a - "am" ou "pm"
A - "AM" ou "PM"
d - comment plusieurs jours, deux chiffres, s'il y a moins de deux chiffres, ajoutez un zéro devant comme : "01" à "31"
D - jour de la semaine, trois lettres anglaises comme : "Fri" < ; 🎜>F - mois, en anglais Nom complet ; par exemple : "Janvier"
h - heure au format 12 heures ; par exemple : "01" à "12"
H - heure au format 24 heures ; : "00" à "23"
g - heure au format 12 heures, n'ajoutez pas de zéros s'il y a moins de deux chiffres comme par exemple : "1" à 12"
G - heure en 24- ; format heure, n'ajoutez pas de zéros s'il y a moins de deux chiffres ; tels que : "0" à "23" "
i - minutes ; tels que : "00" à "59"
j - jours, deux chiffres, s'il y a moins de deux chiffres, aucun zéro n'est ajouté tel que : "1" à "31"
l - Jour de la semaine, nom anglais complet tel que : "Friday"
m ; - mois, deux chiffres, s'il y a moins de deux chiffres, ajoutez des zéros devant tel que : "01" à "12"
n - mois, Deux chiffres, s'il y a moins de deux chiffres, aucun zéro ne sera être ajouté ; tel que : "1" à "12"
M - mois, trois lettres anglaises telles que : "Jan"
s - secondes telles que : "00" à "59"
 ; S - ajoutez un nombre ordinal anglais à la fin du mot, deux lettres anglaises telles que : "th", "nd"
t - précisez le nombre de jours dans le mois tel que : "28" à " ; 31"
U - nombre total de secondes
w - jour numérique de la semaine, tel que : "0" (dimanche) à "6" (samedi)
Y - année, quatre chiffres ; tel que : " 1999"
y - année, deux chiffres ; tels que : "99"
z - jour de l'année ; tels que : "0" à "365"
Les autres caractères non répertoriés ci-dessus sont répertoriés directement. caractère. Exemple :

Tuesday
Tuesday 23rd of June 2009 05:26:19 AM
Oct 3,1975 was on a Thursday
Tue, 23 Jun 09 05:26:19 +0000
1975-10-02T16:00:00+00:00
Copier après la connexion

六:
getdate() 函数取得日期/时间信息。
getdate(timestamp)
timestamp可选 规定UNIX时间格式中的时间,没有则为当前时间
他返回一个根据 timestamp 得出的包含有日期信息的结合数组。如果没有给出时间戳,则认为是当前本地时间。

数组中的单元如下:
"seconds" 秒的数字表示 0 到 59
"minutes" 分钟的数字表示 0 到 59
"hours" 小时的数字表示 0 到 23
"mday" 月份中第几天的数字表示 1 到 31
"wday" 星期中第几天的数字表示 0(表示星期天)到 6(表示星期六)
"mon" 月份的数字表示 1 到 12
"year" 4 位数字表示的完整年份 例如:1999 或 2003
"yday" 一年中第几天的数字表示 0 到 365
"weekday" 星期几的完整文本表示 Sunday 到 Saturday
"month" 月份的完整文本表示 January 到 December
0 自从 Unix 纪元开始至今的秒数,和 time() 的返回值以及用于 date() 的值类似。 系统相关,典型值为从 -2147483648 到 2147483647。
例子:

<?php
print_r(getdate());
?>
Copier après la connexion

显示:

Array
(
[seconds] => 45
[minutes] => 52
[hours] => 14
[mday] => 24
[wday] => 2
[mon] => 1
[year] => 2006
[yday] => 23
[weekday] => Tuesday
[month] => January
[0] => 1138110765
)
Copier après la connexion

例子2:

<?php
$my_t=getdate(date("U"));
print("$my_t[weekday], $my_t[month] $my_t[mday], $my_t[year]");
?>
Copier après la connexion

显示:

Wednesday, January 25, 2006
Copier après la connexion

七:
gettimeofday() 函数返回一个包含当前时间信息的数组。
所返回的数组键的含义是:
"sec" - 自 Unix 纪元起的秒数
"usec" - 微秒数
"minuteswest" - 格林威治向西的分钟数
"dsttime" - 夏令时修正的类型
gettimeofday(return_float)
return_float 可选。当其设置为 TRUE 时,gettimeofday() 会返回一个浮点数。
例子1

<?php
echo(gettimeofday(true) . "<br /><br />");
print_r(gettimeofday());
?>
Copier après la connexion

显示:

1138111447.4
Copier après la connexion
Array
(
[sec] => 1138111447
[usec] => 395863
[minuteswest] => -60
[dsttime] => 0
)
Copier après la connexion

例子2:

<?php
$my_t=gettimeofday();
print("$my_t[sec].$my_t[usec]");
?>
Copier après la connexion

显示:

1138197006.988273
Copier après la connexion

八:
mktime() 函数返回一个日期的 Unix 时间戳。
gmmktime() 函数取得 GMT 日期的 UNIX 时间戳。与 mktime() 类似,不同的是返回值是格林威治标准时的时间戳。
参数总是表示 GMT 日期,因此 is_dst 对结果没有影响。与 mktime() 一样,参数可以从右到左依次空着,空着的参数会被设为

相应的当前 GMT 值。
mktime(hour,minute,second,month,day,year,is_dst)
参数可以从右到左依次空着,空着的参数会被设为相应的当前 格林威治GMT 值。
hour 可选。规定小时。
minute 可选。规定分钟。
second 可选。规定秒。
month 可选。规定用数字表示的月。
day 可选。规定天。
year 可选。规定年。在某些系统上,合法值介于 1901 - 2038 之间。不过在 PHP 5 中已经不存在这个限制了。
is_dst 可选。如果时间在日光节约时间(DST)期间,则设置为1,否则设置为0,若未知,则设置为-1。
自 5.1.0 起,is_dst 参数被废弃。因此应该使用新的时区处理特性。
例子
mktime() 函数对于日期运算和验证非常有用。它可以自动校正越界的输入:

<?php
echo(date("M-d-Y",mktime(0,0,0,12,36,2001)));
echo(date("M-d-Y",mktime(0,0,0,14,1,2001)));
echo(date("M-d-Y",mktime(0,0,0,1,1,2001)));
echo(date("M-d-Y",mktime(0,0,0,1,1,99)));
?>
Copier après la connexion

输出:

Jan-05-2002
Feb-01-2002
Jan-01-2001
Jan-01-1999
Copier après la connexion

九:
strftime() 函数根据区域设置格式化本地时间/日期。
gmstrftime() 函数根据本地区域设置格式化 GMT/UTC 时间/日期。与 strftime() 的行为相同,不同的是返回时间是格林威治标准时(GMT
)。
strftime(format,timestamp)
format 可选。规定如何返回结果。
timestamp 可选。
例子:

<?php
echo(strftime("%b %d %Y %X", mktime(20,0,0,12,31,98)));
echo(gmstrftime("%b %d %Y %X", mktime(20,0,0,12,31,98)));
//输出当前日期、时间和时区
echo(gmstrftime("It is %a on %b %d, %Y, %X time zone: %Z",time()));
?>
Copier après la connexion

显示:

Dec 31 1998 20:00:00
Dec 31 1998 19:00:00
It is Wed on Jan 25, 2006, 11:32:10 time zone: W. Europe Standard Time
Copier après la connexion

十:
idate() 函数将本地时间/日期格式化为整数。
与 date() 不同,idate() 只接受一个字符作为 format 参数。
strftime(format,timestamp)
format 可选。规定如何返回结果。
B Swatch Beat/Internet Time
d 月份中的第几天
h 小时(12 小时格式)
H 小时(24 小时格式)
i 分钟
I 如果启用夏时制则返回 1,否则返回 0
L 如果是闰年则返回 1,否则返回 0
m 月份的数字
s 秒数
t 本月的总天数
U 自 Unix 纪元(January 1 1970 00:00:00 GMT)起的秒数――这和 time() 作用相同
w 星期中的第几天(星期天是 0)
W ISO-8601 格式年份中的第几个星期,每星期从星期一开始
y 年份(1 或 2 位数字――见下面说明)
Y 年份(4 位数字)
z 年份中的第几天
Z 以秒为单位的时区偏移量
timestamp 可选。默认值为本地当前时间,即 time() 的值。
例子:

<?php
echo(idate("Y"));
?>
Copier après la connexion

显示

2009
Copier après la connexion

十一:
localtime() 函数返回本地时间(一个数组)。
localtime(timestamp,is_associative)参数 描述
timestamp 可选。规定被格式化的日期或时间。若未规定 timestamp,则使用当前的本地时间。
is_associative 可选。规定返回索引数组还是关联数组。
localtime() 的第一个参数是时间戳,如果没有给出则使用从 time() 返回的当前时间。
第二个参数是 is_associative,如果设为 false 或未提供则返回的是普通的数字索引数组。如果该参数设为 true 则 localtime() 函数返
回一个关联数组。
关联数组中不同的键名是:
"tm_sec" - 秒数
"tm_min" - 分钟数
"tm_hour" - 小时
"tm_mday" - 月份中的第几日
"tm_mon" - 年份中的第几个月,从 0 开始表示一月
"tm_year" - 年份,从 1900 开始
"tm_wday" - 星期中的第几天
"tm_yday" - 一年中的第几天
"tm_isdst" - 夏令时当前是否生效
注释:月份从 0(一月)到 11(十二月),星期数从 0(星期天)到 6(星期六)。
例子:

<?php
$localtime = localtime();
$localtime_assoc = localtime(time(), true);
print_r($localtime);
print_r($localtime_assoc);
?>
Copier après la connexion

显示:

Array
(
    [0] => 24
    [1] => 3
    [2] => 19
    [3] => 3
    [4] => 3
    [5] => 105
    [6] => 0
    [7] => 92
    [9] => 1
)
Copier après la connexion

十一:
microtime() 函数返回当前 Unix 时间戳和微秒数。
microtime(get_as_float)
get_as_float 如果给出了 get_as_float 参数并且其值等价于 TRUE,该函数将返回一个浮点数。
如果调用时不带可选参数,本函数以 "msec sec" 的格式返回一个字符串,其中 sec 是自 Unix 纪元(0:00:00 January 1, 1970 GMT)起到
现在的秒数,msec 是微秒部分。字符串的两部分都是以秒为单位返回的。
例子:

<?php
echo(microtime());
?>
Copier après la connexion

显示:

0.25139300 1138197510
Copier après la connexion

十二:
strptime() 函数解析由 strftime() 生成的日期/时间。
strptime(date,format)
date 要解析的字符串(例如从 strftime() 返回的)。
format date 所使用的格式(与 strftime() 中所使用的相同)。
strptime() 返回一个将 date 解析后的数组,如果出错返回 FALSE。
月份和星期几的名字以及其它与语种有关的字符串对应于 setlocale()设定的当前区域(LC_TIME)。
数组中包含以下单元:
键名 说明
tm_sec 当前分钟内的秒数(0-61)
tm_min 当前小时内的分钟数(0-59)
tm_hour 午夜起的小时数(0-23)
tm_mday 月份中的第几天(1-31)
tm_mon 自一月起过了几个月(0-11)
tm_year 自 1900 年起过了几年
tm_wday 自星期天起过了几天(0-6)
tm_yday 本年自一月一日起过了多少天(0-365)
unparsed date 中未能通过指定的 format 识别的部分
例子:

<php
$format="%d/%m/%Y %H:%M:%S";
$strf=strftime($format);
echo("$strf");
print_r(strptime($strf,$format));
?>
Copier après la connexion

显示:

03/10/2005 13:23:44
Array
(
[tm_sec] => 44
[tm_min] => 23
[tm_hour] => 13
[tm_mday] => 3
[tm_mon] => 9
[tm_year] => 105
[tm_wday] => 0
[tm_yday] => 276
[unparsed] =>
)
Copier après la connexion

十三:
date_sunrise() 函数返回指定的日期与地点的日出时间。
date_sunrise(timestamp,format,latitude,longitude,zenith,gmt_offset)
date_sunset() 函数返回指定的日期与地点的日落时间。
date_sunset(timestamp,format,latitude,longitude,zenith,gmt_offset)
1timestamp 必需。
2format 可选。规定如何返回结果:
SUNFUNCS_RET_STRING (以 string 格式返回结果,比如 16:46)
SUNFUNCS_RET_DOUBLE (以 float 格式返回结果,比如 16.78243132)
SUNFUNCS_RET_TIMESTAMP (以 integer 格式(时间戳)返回结果,比如 1095034606)
3latitude 可选。规定地点的纬度。默认是指北纬。因此如果要指定南纬,必须传递一个负值。
4longitude 可选。规定地点的经度。默认是指东经。因此如果要指定西经,必须传递一个负值。
5zenith 可选。
6gmt_offset 可选。规定 GMT 与本地时间的差值。单位是小时。
例子1:

<?php
//计算葡萄牙里斯本的日出时间
//Latitude: 北纬 38.4 度
//Longitude: 西经 9 度
//Zenith ~= 90
//offset: +1 GMT
echo("Date: " . date("D M d Y") . "<br />");
echo("Sunrise time: ");
echo(date_sunrise(time(),SUNFUNCS_RET_STRING,38.4,-9,90,1));
?>
Copier après la connexion

显示

Date: Tue Jan 24 2006
Sunrise time: 08:52
Copier après la connexion

例子2 :

<?php
//计算葡萄牙里斯本的日落时间
//Latitude: 北纬 38.4 度
//Longitude: 西经 9 度
//Zenith ~= 90
//offset: +1 GMT
echo("Date: " . date("D M d Y") . "<br />");
echo("Sunrise time: ");
echo(date_sunset(time(),SUNFUNCS_RET_STRING,38.4,-9,90,1));
?>
Copier après la connexion

显示

Date: Tue Jan 24 2006
Sunrise time: 18:44
Copier après la connexion

十四:
strtotime() 函数将任何英文文本的日期时间描述解析为 Unix 时间戳。
strtotime(time,now)
time 规定要解析的时间字符串。
now 用来计算返回值的时间戳。如果省略该参数,则使用当前时间。
该函数预期接受一个包含美国英语日期格式的字符串并尝试将其解析为 Unix 时间戳(自 January 1 1970 00:00:00 GMT 起的秒数),其值
相对于 now 参数给出的时间,如果没有提供此参数,则用系统当前时间。
该函数将使用 TZ 环境变量(如果有的话)来计算时间戳。自 PHP 5.1.0 起有更容易的方法来定义时区用于所有的日期/时间函数。此过程
在 date_default_timezone_get() 函数页面中有说明。
例子:

<?php
echo(strtotime("now"));
echo(strtotime("3 October 2005"));
echo(strtotime("+5 hours"));
echo(strtotime("+1 week"));
echo(strtotime("+1 week 3 days 7 hours 5 seconds"));
echo(strtotime("next Monday"));
echo(strtotime("last Sunday"));
?>
Copier après la connexion

显示:

1138614504
1128290400
1138632504
1139219304
1139503709
1139180400
1138489200
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal