PHP强化之04 - 时间 Date/Time

作者: 四月不见 | 来源:发表于2018-07-10 15:53 被阅读13次

    一、语法

    1、简介

    日期和时间信息在 PHP 内部是以 64 位数字存储的, 它可以覆盖当前时间前后 2920 亿年的时间,这个范围之广,足以满足现有应用的实际需求。

    2、时区的设置

    1)修改ini文件

    如:

    date.timezone = Asia/Shanghai
    

    2)date_default_timezone_set函数

    如:

    date_default_timezone_set('America/Los_Angeles');
    

    可以使用函数 date_default_timezone_get()查看你当前服务器的默认时区。

    3)ini_set函数

    ini_set('date.timezone','Asia/Shanghai'); 
    

    3、“2038年问题”

    2038年1月19日凌晨3:14:07(UTC)是自1970年1月1日0点后的2147483647秒。2147483647有什么特殊?它恰好是(2的31次方-1),如果使用32位表示一个有符号整数,这将是可表示的最大整数(第32位用来表示正负号)。

    有效的时间戳典型范围是格林威治时间 1901 年 12 月 13 日 20:45:54 到 2038 年 1 月 19 日 03:14:07。(此范围符合 32 位有符号整数的最小值和最大值)。不过在 PHP 5.1 之前此范围在某些系统(如 Windows)中限制为从 1970 年 1 月 1 日到 2038 年 1 月 19 日。

    二、常用方法

    1、日期格式化

    1)date — 格式化一个本地时间/日期

    string date ( string $format [, int $timestamp ] )
    

    timestamp 是可选的,默认值为 time()。

    format 参数的字符串列表:

    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 到 365
    星期 --- ---
    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: 1999 or 2003
    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>
    u 毫秒 (PHP 5.2.2 新加)。需要注意的是date()函数总是返回 000000 因为它只接受 integer参数, 而 DateTime::format()才支持毫秒。 示例: 654321
    时区 --- ---
    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
    完整的日期/时间 --- ---
    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()

    2)strftime — 根据区域设置格式化本地时间/日期

    string strftime ( string $format [, int $timestamp = time() ] )

    返回用给定的格式字串对给出的 timestamp 进行格式输出后的字符串。如果没有给出时间戳则用当前的本地时间。月份和星期几以及其它和语言有关的字符串写法和用 setlocale() 设定的当前的区域有关。

    相关函数:
    setlocale() — 设置地区信息

    2、获取日期详情

    1)getdate — 取得日期/时间信息

    array getdate ([ int $timestamp = time() ] )
    

    返回一个根据 timestamp 得出的包含有日期信息的关联数组 array。如果没有给出时间戳则认为是当前本地时间。

    返回的关联数组中的键名单元:

    键名 说明 返回值例子
    "seconds" 秒的数字表示 059
    "minutes" 分钟的数字表示 059
    "hours" 小时的数字表示 023
    "mday" 月份中第几天的数字表示 131
    "wday" 星期中第几天的数字表示 0 (周日) 到 6 (周六)
    "mon" 月份的数字表示 112
    "year" 4 位数字表示的完整年份 比如: 19992003
    "yday" 一年中第几天的数字表示 0365
    "weekday" 星期几的完整文本表示 SundaySaturday
    "month" 月份的完整文本表示,比如 January 或 March JanuaryDecember
    0 自从 Unix 纪元开始至今的秒数,和 time()的返回值以及用于 date()的值类似。 系统相关,典型值为从 -21474836482147483647

    例:

    $today = getdate();
    print_r($today);
    
    //结果如下
    Array
    (
        [seconds] => 36
        [minutes] => 23
        [hours] => 15
        [mday] => 10
        [wday] => 2
        [mon] => 7
        [year] => 2018
        [yday] => 190
        [weekday] => Tuesday
        [month] => July
        [0] => 1531207416
    )
    

    相关函数:
    localtime() — 取得本地时间,返回一个关联数组

    3、取得一个日期的时间戳

    1)time — 返回当前的 Unix 时间戳

    int time ( void )

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

    该函数是php时间函数中使用频率最高的一个函数,相信大家对它都已经非常了解,这里就不多做介绍了。

    相关函数:

    microtime() - 返回当前 Unix 时间戳和微秒数

    2)strtotime — 将任何字符串的日期时间描述解析为 Unix 时间戳

    int strtotime ( string $time [, int $now = time() ] )

    例:

    //昨天此刻的时间,明天则是 "1 days",前天则是"-2 days";
    date("Y-m-d H:i:s", strtotime("-1 days")) 
    
    //今天此刻的时间,等价于date("Y-m-d H:i:s")
    date("Y-m-d H:i:s", strtotime("0 days")) 
    
    //昨天此刻的时间,明天则是 "1 days",前天则是"-2 days";
    date("Y-m-d H:i:s", strtotime("-1 days")) 
    
    //今天此刻的时间,等价于date("Y-m-d H:i:s")
    date("Y-m-d H:i:s", strtotime("0 days")) 
    
    //获取指定日期$date所在月的第一天和最后一天
    $firstday = date("Y-m-01", strtotime($date));
    $lastday = date("Y-m-d", strtotime("$firstday +1 month -1 day"));
    
    //获得指定日期$day所在星期的第一天和最后一天
    $lastday = date('Y-m-d', strtotime("$day Sunday"));
    $firstday = date('Y-m-d', strtotime("$lastday -6 days"));
    

    3)mktime — 取得一个日期的 Unix 时间戳

    int mktime ([ int $hour = date("H") [, int $minute = date("i") [, int $second = date("s") [, int $month = date("n") [, int $day = date("j") [, int $year = date("Y") [, int $is_dst = -1 ]]]]]]] )

    根据给出的参数返回 Unix 时间戳。时间戳是一个长整数,包含了从 Unix 纪元(January 1 1970 00:00:00 GMT)到给定时间的秒数。

    参数可以从右向左省略,任何省略的参数会被设置成本地日期和时间的当前值。

    mktime()在做日期计算和验证方面很有用,它会自动计算超出范围的输入的正确值。

    例1,下面例子中每一行都会产生字符串"Jan-01-1998":

    echo date("M-d-Y", mktime(0, 0, 0, 12, 32, 1997));
    echo date("M-d-Y", mktime(0, 0, 0, 13, 1, 1997));
    echo date("M-d-Y", mktime(0, 0, 0, 1, 1, 1998));
    echo date("M-d-Y", mktime(0, 0, 0, 1, 1, 98));
    

    例2,计算下个月的最后一天:

    任何给定月份的最后一天都可以被表示为下个月的第 "0" 天,而不是 -1 天。下面两个例子都会产生字符串 "The last day in Feb 2000 is: 29"

    $lastday = mktime(0, 0, 0, 3, 0, 2000);
    echo strftime("Last day in Feb 2000 is: %d", $lastday);
    $lastday = mktime(0, 0, 0, 4, -31, 2000);
    echo strftime("Last day in Feb 2000 is: %d", $lastday);
    

    其它常用方法

    参考:

    官方文档:

    相关书籍:

    • 《PHP经典实例》 David Sklar & Adam Trachtenberg

    --《最后更新时间:2018/6/25》--

    相关文章

      网友评论

        本文标题:PHP强化之04 - 时间 Date/Time

        本文链接:https://www.haomeiwen.com/subject/xghxsftx.html