php中文日期 setlocale和strftime区域化 时间差 倒计时 问题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
setlocale:
setlocale() 函数设置地区信息(地域信息)。
地区信息是针对一个地理区域的语言、货币、时间以及其他信息。
该函数返回当前的地区设置,若失败则返回false。
语法setlocale(constant,location)
constant 必需。
规定应该设置什么地区信息。
可用的常量:
LC_ALL - 包括下面的所有选项LC_COLLATE -排序次序LC_CTYPE - 字符类别及转换(例如所有字符大写或小写)LC_MESSAGES - 系统消息格式LC_MONETARY - 货币格式LC_NUMERIC - 数字格式LC_TIME - 日期/时间格式
location 必需。
规定把地区信息设置为什么国家/地区。
如果location 参数是数组,setlocale() 会尝试每个数组元素,直到找到合法的语言或地区代码为止。
如果某个地区在不同的系统上拥有不同的名称,这一点很有用。
注释:在此查找语言和地区代码。
提示和注释
注释:setlocale() 函数仅针对当前脚本改变地区信息。
提示:可以通过setlocale(LC_ALL,NULL) 把地区信息设置为系统默认。
例子
在本例中,我们将把locale 设置为US English,然后再设置回系统默认:
<?
php echo setlocale(LC_ALL,"En-Us");
echo setlocale(LC_ALL,NULL);
?>
strftime:
strftime —根据区域设置格式化本地时间/日期
string strftime( string$format [, int$timestamp ] )
返回用给定的格式字串对给出的timestamp进行格式输出后的字符串。
如果没有给出时间戳则用当前的本地时间。
月份和星期几以及其它和语言有关的字符串写法和用setlocale()设定的当前的区域有关。
格式字串能识别下列转换标记:
%a - 当前区域星期几的简写
%A - 当前区域星期几的全称
%b - 当前区域月份的简写
%B - 当前区域月份的全称
%c - 当前区域首选的日期时间表达
%C - 世纪值(年份除以100 后取整,范围从00 到99)
%d - 月份中的第几天,十进制数字(范围从01 到31)
%D - 和%m/%d/%y 一样
%e - 月份中的第几天,十进制数字,一位的数字前会加上一个空格(范围从' 1' 到'31')%g - 和
%G 一样,但是没有世纪
%G - 4 位数的年份,符合ISO 星期数(参见%V)。
和
%V 的格式和值一样,只除了如果ISO 星期数属于前一年或者后一年,则使用那一年。
%h - 和%b 一样%H - 24 小时制的十进制小时数(范围从00 到23)
%I - 12 小时制的十进制小时数(范围从00 到12)
%j - 年份中的第几天,十进制数(范围从001 到366)
%m - 十进制月份(范围从01 到12)
%M - 十进制分钟数
%n - 换行符
%p - 根据给定的时间值为`am' 或`pm',或者当前区域设置中的相应字符串
%r - 用a.m. 和p.m. 符号的时间
%R - 24 小时符号的时间
%S - 十进制秒数
%t - 制表符
%T - 当前时间,和%H:%M:%S 一样%u - 星期几的十进制数表达[1,7],1 表示星期一Warning
尽管ISO 9889:1999(当前的C 标准)明确指出一周从星期一开始,但是Sun Solaris 的一周似乎从星期天开始并作为1。
%U - 本年的第几周,从第一周的第一个星期天作为第一天开始%V - 本年第几周的ISO 8601:1988 格式,范围从01 到53,第1 周是本年第一个至少还有4 天的星期,星期一作为每周的第一天。
(用%G 或者%g 作为指定时间戳相应周数的年份组成。
)%W - 本年的第几周数,从第一周的第一个星期一作为第一天开始%w - 星期中的第几天,星期天为0%x - 当前区域首选的时间表示法,不包括时间%X - 当前区域首选的时间表示法,不包括日期%y - 没有世纪数的十进制年份(范围从00 到99)%Y - 包括世纪数的十进制年份%Z 或%z - 时区名或缩写%% - 文字上的`%' 字符
实例:
<?php
echo "<br/>";
setlocale(LC_TIME,"chs"); //设置区域信息为中文时间格式
$weekday = strftime("%A"); //获得区域星期
echo $weekday;
?>
/*
LC_ALL - 包括下面的所有选项
LC_COLLATE -排序次序
LC_CTYPE - 字符类别及转换(例如所有字符大写或小写)
LC_MESSAGES - 系统消息格式
LC_MONETARY - 货币格式
LC_NUMERIC - 数字格式
LC_TIME - 日期/时间格式
*/
/*
%a - 当前区域星期几的简写
%A - 当前区域星期几的全称
%b - 当前区域月份的简写
%B - 当前区域月份的全称
%c - 当前区域首选的日期时间表达
%C - 世纪值(年份除以100 后取整,范围从00 到99)
%d - 月份中的第几天,十进制数字(范围从01 到31)
%D - 和%m/%d/%y 一样
%e - 月份中的第几天,十进制数字,一位的数字前会加上一个空格(范围从' 1' 到'31')
%g - 和%G 一样,但是没有世纪
%G - 4 位数的年份,符合ISO 星期数(参见%V)。
和%V 的格式和值一样,只除了如果ISO 星期数属于前一年或者后一年,则使用那一年。
%h - 和%b 一样
%H - 24 小时制的十进制小时数(范围从00 到23)
%I - 12 小时制的十进制小时数(范围从00 到12)
%j - 年份中的第几天,十进制数(范围从001 到366)
%m - 十进制月份(范围从01 到12)
%M - 十进制分钟数
%n - 换行符
%p - 根据给定的时间值为`am' 或`pm',或者当前区域设置中的相应字符串
%r - 用a.m. 和p.m. 符号的时间
%R - 24 小时符号的时间
%S - 十进制秒数
%t - 制表符
%T - 当前时间,和%H:%M:%S 一样
%u - 星期几的十进制数表达[1,7],1 表示星期一
%U - 本年的第几周,从第一周的第一个星期天作为第一天开始
%V - 本年第几周的ISO 8601:1988 格式,范围从01 到53,第1 周是本年第一个至少还有 4 天的星期,星期一作为每周的第一天。
(用%G 或者%g 作为指定时间戳相应周数的年份组成。
)
%W - 本年的第几周数,从第一周的第一个星期一作为第一天开始
%w - 星期中的第几天,星期天为0
%x - 当前区域首选的时间表示法,不包括时间
%X - 当前区域首选的时间表示法,不包括日期
%y - 没有世纪数的十进制年份(范围从00 到99)
%Y - 包括世纪数的十进制年份
%Z 或%z - 时区名或缩写
%% - 文字上的`%' 字符
*/
================分界线==============================================
<?php
//本地化日期和时间设定
//setlocale("LC_ALL","en_US");//美国
//setlocale("LC_ALL","chs"); //简体中文
//setlocale("LC_ALL","cht"); //繁体中文
//根据本地化设定获得本地环境设置
//strftime();
//date_default_timezone_set("Asia/Hong_Kong");
echo date("Y-m-d H:i:s")."<br/>";
//时间差问题strtotime()
$time1 = date("Y-m-d H:i:s");
$time2 = "2011-07-19 08:30:00";
echo $time1." ".$time2."<br/>"; $time = (strtotime($time2) - strtotime($time1)) / (60 * 60 * 24);
echo ceil($time)."天"; //倒计时通过ceil取整
?>。