目录

PHP - 日期相关计算

日期函数在平时的开发中用的比较广泛,尤其是 date() 函数,强大到让人窒息,其格式之多让人目眩。这里我也只能管中窥豹了,更多的用法请参看官方文档

函数 date 可识别的格式

这里我无耻的抄了一遍手册,不为别的,就是加强一下自己的记忆,见笑了。

时间格式

格式说明返回值
a小写的上午和下午值am 或 pm
A大写的上午和下午值AM 或 PM
BSwatch 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>
u毫秒(PHP 5.2.2 新加)。需要注意的是 date() 函数总是返回 000000 因为它只接受 integer 参数,而 DateTime::format() 才支持毫秒示例: 654321
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<?php

$time = strtotime('2020-06-01 12:59:59');
$array = [
    'a' => date('a', $time),
    'A' => date('A', $time),
    'B' => date('B', $time),
    'g' => date('g', $time),
    'G' => date('G', $time),
    'h' => date('h', $time),
    'H' => date('H', $time),
    'i' => date('i', $time),
    's' => date('s', $time),
    'u' => date('u', $time),
];

print_r($array);

// 结果
Array
(
    [a] => pm
    [A] => PM
    [B] => 249
    [g] => 12
    [G] => 12
    [h] => 12
    [H] => 12
    [i] => 59
    [s] => 59
    [u] => 000000
)

时区格式

格式说明返回值
e时区标识(PHP 5.1.0 新加)例如:UTC,GMT,Atlantic/Azores
I是否为夏令时如果是夏令时为 1,否则为 0
O与格林威治时间相差的小时数例如:+0200
P与格林威治时间(GMT)的差别,小时和分钟之间有冒号分隔(PHP 5.1.3 新加)例如:+02:00
T本机所在的时区例如:EST,MDT(在 Windows 下为完整文本格式,例如:Eastern Standard Time,中文版会显示『中国标准时间』)
Z时差偏移量的秒数。UTC 西边的时区偏移量总是负的,UTC 东边的时区偏移量总是正的-43200 到 43200
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php

$time = strtotime('2020-06-01 12:59:59');
$array = [
    'e' => date('e', $time),
    'I' => date('I', $time),
    'O' => date('O', $time),
    'P' => date('P', $time),
    'T' => date('T', $time),
];

print_r($array);

// 结果
Array
(
    [e] => PRC
    [I] => 0
    [O] => +0800
    [P] => +08:00
    [T] => CST
)

日期时间格式

格式说明返回值
cISO 8601 格式的日期(PHP 5 新加)2004-02-12T15:19:21+00:00
rRFC 822 格式的日期例如:Thu, 21 Dec 2000 16:01:07 +0200
U从 Unix 纪元(January 1 1970 00:00:00 GMT)开始至今的秒数参见 time()
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
<?php

$time = strtotime('2020-06-01 12:59:59');
$array = [
    'c' => date('c', $time),
    'r' => date('r', $time),
    'U' => date('U', $time),
];

print_r($array);

// 结果
Array
(
    [c] => 2020-06-01T12:59:59+08:00
    [r] => Mon, 01 Jun 2020 12:59:59 +0800
    [U] => 1590987599
)

日格式

格式说明返回值
d月份中的第几天,有前导零的 2 位数字01 到 31
D星期中的第几天,文本表示,3 个字母Mon 到 Sun
j月份中的第几天,没有前导零1 到 31
l星期几,完整的文本格式Sunday 到 Saturday
NISO-8601 格式数字表示的星期中的第几天(PHP 5.1.0 新加)1(表示星期一)到 7(表示星期天)
S每月天数后面的英文后缀,2 个字符st,nd,rd 或者 th。可以和 j 一起用
w星期中的第几天,数字表示0(表示星期天)到 6(表示星期六)
z年份中的第几天0 到 365
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<?php

$time = strtotime('2020-06-01 12:59:59');
$array = [
    'd' => date('d', $time),
    'D' => date('D', $time),
    'j' => date('j', $time),
    'l' => date('l', $time),
    'N' => date('N', $time),
    'S' => date('S', $time),
    'w' => date('w', $time),
    'z' => date('z', $time),
];

print_r($array);

// 结果
Array
(
    [d] => 01
    [D] => Mon
    [j] => 1
    [l] => Monday
    [N] => 1
    [S] => st
    [w] => 1
    [z] => 152
)

星期格式

格式说明返回值
WISO-8601 格式年份中的第几周,每周从星期一开始(PHP 4.1.0 新加的)例如:42(当年的第 42 周)
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
<?php

$time = strtotime('2020-06-01 12:59:59');
$array = [
    'W' => date('W', $time),
];

print_r($array);

// 结果
Array
(
    [W] => 23
)

月格式

格式说明返回值
F月份,完整的文本格式,例如 January 或者 MarchJanuary 到 December
m数字表示的月份,有前导零01 到 12
M三个字母缩写表示的月份Jan 到 Dec
n数字表示的月份,没有前导零1 到 12
t指定的月份有几天28 到 31
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
<?php

$time = strtotime('2020-06-01 12:59:59');
$array = [
    'F' => date('F', $time),
    'm' => date('m', $time),
    'M' => date('M', $time),
    'n' => date('n', $time),
    't' => date('t', $time),
];

print_r($array);

// 结果
Array
(
    [F] => June
    [m] => 06
    [M] => Jun
    [n] => 6
    [t] => 30
)

年格式

格式说明返回值
L是否为闰年如果是闰年为 1,否则为 0
oISO-8601 格式年份数字。这和 Y 的值相同,只除了如果 ISO 的星期数(W)属于前一年或下一年,则用那一年。(PHP 5.1.0 新加)例如:1999 or 2003
Y4 位数字完整表示的年份例如:1999 或 2003
y2 位数字表示的年份例如:99 或 03
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
<?php

$time = strtotime('2020-06-01 12:59:59');
$array = [
    'L' => date('L', $time),
    'o' => date('o', $time),
    'Y' => date('Y', $time),
    'y' => date('y', $time),
];

print_r($array);

// 结果
Array
(
    [L] => 1
    [o] => 2020
    [Y] => 2020
    [y] => 20
)

计算指定日期时间

当前日期时间的相对计算

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<?php

date_default_timezone_set('PRC');

$array = [
    '当前日期时间' => date('Y-m-d H:i:s'),
    '前一天的此时日期时间' => date('Y-m-d H:i:s', strtotime('-1 day')),
    '后一天的此时日期时间' => date('Y-m-d H:i:s', strtotime('+1 day')),
    '上一个月的此时日期时间' => date('Y-m-d H:i:s', strtotime('-1 month')),
    '下一个月的此时日期时间' => date('Y-m-d H:i:s', strtotime('+1 month')),
    '加 1 月 2 周 3 天 4 时 5 分 6 秒的此时日期时间' => date('Y-m-d H:i:s', strtotime('+1 month +2 weeks +3 days +4 hours +5 minutes +6 seconds')),
];

print_r($array);

// 结果
Array
(
    [当前日期时间] => 2018-04-13 21:24:30
    [前一天的此时日期时间] => 2018-04-12 21:24:30
    [后一天的此时日期时间] => 2018-04-14 21:24:30
    [上一个月的此时日期时间] => 2018-03-13 21:24:30
    [下一个月的此时日期时间] => 2018-05-13 21:24:30
    [ 1  2  3  4  5  6 秒的此时日期时间] => 2018-05-31 01:29:36
)

起始结束日期时间的计算

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<?php

date_default_timezone_set('PRC');

$array = [
    '本周起始日期时间' => date('Y-m-d H:i:s', mktime(0, 0, 0, date('m'), date('d') - date('w') + 1 - 5, date('Y'))),
    '本周结束日期时间' => date('Y-m-d H:i:s', mktime(23, 59, 59, date('m'), date('d') - date('w') + 7 - 5, date('Y'))),
    '上月起始日期时间' => date('Y-m-d H:i:s', mktime(0, 0, 0, date('m') - 1, 1, date('Y'))),
    '上月结束日期时间' => date('Y-m-d H:i:s', mktime(23, 59, 59, date('m'), 0, date('Y'))),
    '本月起始日期时间' => date('Y-m-d H:i:s', mktime(0, 0, 0, date('m'), 1, date('Y'))),
    '本月结束日期时间' => date('Y-m-d H:i:s', mktime(23, 59, 59, date('m'), date('t'), date('Y'))),
    '下月起始日期时间' => date('Y-m-d H:i:s', mktime(0, 0, 0, date('m') + 1, 1, date('Y'))),
    '下月结束日期时间' => date('Y-m-d H:i:s', mktime(23, 59, 59, date('m') + 1, date('t') + 1, date('Y'))),
];
print_r($array);

// 结果
Array
(
    [本周起始日期时间] => 2018-04-04 00:00:00
    [本周结束日期时间] => 2018-04-10 23:59:59
    [上月起始日期时间] => 2018-03-01 00:00:00
    [上月结束日期时间] => 2018-03-31 23:59:59
    [本月起始日期时间] => 2018-04-01 00:00:00
    [本月结束日期时间] => 2018-04-30 23:59:59
    [下月起始日期时间] => 2018-05-01 00:00:00
    [下月结束日期时间] => 2018-05-31 23:59:59
)