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 - 月份,三個英文字母; 如: "Ja n"
s - 秒; 如: "00" 至 "59"
S - 字尾加英文序數,二個英文字母; 如: "th","nd"
t - 指定月份的天數; 如: "28" 至 "31"
U - 總秒數
w - 數位型的星期幾,如: "0" (星期日) 至 "6" (星期六)
Y - 年,四位數位; 如: "1999 "
y - 年,二位數位; 如: "99"
z - 一年中的第幾天; 如: "0" 至 "365"
其它不在上列的字元則直接列出該字元。
使用範例,範例一:
<?
print(date( "l dS of F Y h:i:s A" ));
print("July 1, 2000 is on a " . date("l", mktime(0,0,0,7,1,2000)));
?>
範例二:
<?
$tomorrow = mktime(0,0,0,date("m") ,date("d")+1,date("Y"));
$lastmonth = mktime(0,0,0,date(" m")-1,date("d"), date("Y"));
$nextyear = mktime(0,0,0,date("m"), date("d", date("Y")+1);
?>
參考 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 時區或名稱縮寫。
%% % 字元。
使用範例
<?php
setlocale ("LC_TIME", "C");
print(strftime("%A in Finnish is "));
setlocale ("LC_TIME", "fi");
print(strftime("%A, in French "));
setlocale ("LC_TIME", "fr");
print(strftime("%A and in German "));
setlocale ("LC_TIME", "de");
print(strftime("%A.n"));
?>