php时间函数time(),date(),mktime()区别


 



php时间函数time(),date(),mktime()区别

php :time(),date(),mktime()日期与时间函数库{经常会忘却掉}


checkdate : 验证日期的正确性。 

date : 将服务器的时间格式化。 

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

getdate : 获得时间及日期信息。 

gettimeofday : 取得目前时间。 

gmdate : 取得目前与 GMT 差后的时间。 

easter_date : 计算复活节日期。 

easter_days : 计算复活节与三月廿一日之间日期数。 

mktime : 取得 UNIX 时间戳记。 

gmmktime : 取得 UNIX 时间戳记的格林威治时间。 

time : 取得目前时间的 UNIX 时间戳记。 

microtime : 取得目前时间的 UNIX 时间戳记的百万分之一秒值。 


  checkdate 验证日期的正确性。

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

  返回值: 整数

  函数种类: 时间日期

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

   年 为 0 至 32767 年

  月 为 1 至 12 月

  日 则随着月份及闰年变化

  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" 



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

  使用范例,范例一:

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

复制代码

  范例二:

  1.         <? 
  2.           $tomorrow = mktime(0,0,0,date("m") ,date("d")+1,date("Y")); 
  3.           $lastmonth = mktime(0,0,0,date("m")-1,date("d"), date("Y")); 
  4.           $nextyear = mktime(0,0,0,date("m"), date("d", date("Y")+1); 
  5.         ?> 

复制代码

  参考 gmdate() mktime()

  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 时区或名称缩写。 

%% % 字符。 



  使用范例

  1.         <?php 
  2.           setlocale ("LC_TIME", "C"); 
  3.           print(strftime("%A in Finnish is ")); 
  4.           setlocale ("LC_TIME", "fi"); 
  5.           print(strftime("%A, in French ")); 
  6.           setlocale ("LC_TIME", "fr"); 
  7.           print(strftime("%A and in German ")); 
  8.           setlocale ("LC_TIME", "de"); 
  9.           print(strftime("%A.n")); 
  10.         ?> 

复制代码