程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> php的日期處理函數及uchome的function_coomon中日期處理函數的研究

php的日期處理函數及uchome的function_coomon中日期處理函數的研究

編輯:PHP綜合
復制代碼 代碼如下:
<?php echo time();
echo mktime(11,25,0,9,5,2010);//和time一樣的
echo microtime();
echo mktime(0,0,0,1,1,1970);
?>

這裡面輸出分別是1283657290、1283657100、0.88533200 1283657290、-25200。從最後一個值看,我們知道這裡返回的時間戳是經過了時區調整的,也就是我在中國的1970年1月1日0點,格林尼治還沒有到0點呢,於是這裡的時間會是負數且整好等於-8*3600。

再看
復制代碼 代碼如下:
<?php
echo date ("H i l d F" ,1283657100);
echo gmdate("H i l d F",1283657100);
echo strftime("%Hh%M %A %d %b" ,1283657100);
//strftime()工作的方式和date()沒有什麼不同,除了特殊格式化字符的前面必須添加一個百分號%。
echo strtotime("2010-9-5 11:25:00");
var_dump(getdate (time()));
?>

這裡的輸出是11 25 Sunday 05 September、03 25 Sunday 05 September、11h25 Sunday 05 Sep、1283657100、array(11) {
["seconds"]=>
int(9)
["minutes"]=>
int(39)
["hours"]=>
int(11)
["mday"]=>
int(5)
["wday"]=>
int(0)
["mon"]=>
int(9)
["year"]=>
int(2010)
["yday"]=>
int(247)
["weekday"]=>
string(6) "Sunday"
["month"]=>
string(9) "September"
[0]=>
int(1283657949)
}

主要看第三個輸出,這裡輸出的是在中國的2010年9月5日11點25分的時候 格林尼治的時間是多少。這裡也要計入時差的。而且這裡還有一個很奇妙的就是只有gmdate沒有發出警告,其余的都有警告說不能依賴於系統的時區。想象也是,因為gmdate算出來的只是格林尼治的時間,就算是系統時區錯了,一加一減就又正常了。
復制代碼 代碼如下:
//時間格式化
function sgmdate($dateformat, $timestamp='', $format=0) {
global $_SCONFIG, $_SGLOBAL;
if(empty($timestamp)) {
$timestamp = $_SGLOBAL['timestamp'];
}
$timeoffset = strlen($_SGLOBAL['member']['timeoffset'])>0?intval($_SGLOBAL['member']['timeoffset']):intval($_SCONFIG['timeoffset']);
$result = '';
if($format) {
$time = $_SGLOBAL['timestamp'] - $timestamp;
if($time > 24*3600) {
$result = gmdate($dateformat, $timestamp + $timeoffset * 3600);
} elseif ($time > 3600) {
$result = intval($time/3600).lang('hour').lang('before');
} elseif ($time > 60) {
$result = intval($time/60).lang('minute').lang('before');
} elseif ($time > 0) {
$result = $time.lang('second').lang('before');
} else {
$result = lang('now');
}
} else {
$result = gmdate($dateformat, $timestamp + $timeoffset * 3600);
}
return $result;
}

我們直接看if($format){}裡的東西,首先求得系統當前時間和我傳進來的時間(一般是數據庫裡的時間,如2010-9-4 21:00:00)的差。如果時間差是在一天以內,則直接得出結論比如兩小時前,如果是大於1天,則調用gmdate。這裡我就是很搞不懂的。為什麼要調用這個詭異的函數,而不是直接date($timestamp)呢?這他媽的到底是什麼意思阿?
gmdate

When run in Finland (GMT +0200), the first line below prints "Jan 01 1998 00:00:00", while the second prints "Dec 31 1997 22:00:00".
復制代碼 代碼如下:
<?php
echo date("M d Y H:i:s", mktime(0, 0, 0, 1, 1, 1998));
echo gmdate("M d Y H:i:s", mktime(0, 0, 0, 1, 1, 1998));
?>

也就是說gmdate是考慮過了時差的。這裡會輸出標准的時間格式,而不是幾天前。
接下來著重看uchome的function_common裡的函數
復制代碼 代碼如下:
//字符串時間化
function sstrtotime($string) {
global $_SGLOBAL, $_SCONFIG;
$time = '';
if($string) {
$time = strtotime($string);
if(gmdate('H:i', $_SGLOBAL['timestamp'] + $_SCONFIG['timeoffset'] * 3600) != date('H:i', $_SGLOBAL['timestamp'])) {
$time = $time - $_SCONFIG['timeoffset'] * 3600;
}
}
return $time;
}

別看這個函數很少,但是看得我很吃力。這裡是要把一個時間字符串轉換為時間戳。比如我這裡輸入的是2010 9 4 21:08,則$time的值就是這個時間到January 1 1970 00:00:00 GMT的時間差,這裡是要考慮什麼時差的。$_SGLOBAL[''timestamp]的值其實和$time一樣的方法算出來的,但是數值可能有細小的差別。$_SCONFIG['timeoffset']是在config的那個表裡面的,目前其值為8。這裡有一種情況是系統的時區是對的,或者是不對的,需要通過$_SCONFIG['timeoffset']來檢驗。gmdate將傳入的時間戳(運行程序的地方的時間戳)經過系統的時區來得到此時格林尼治那個地方的時間。如果是系統時區設對了,那麼這個正好一加一減,和後面的相等了(其實這裡$_SGLOBAL[''timestamp]的數值是無關緊要的)。如果是正常的,那麼就不需要改$time,如果是不正常的,那麼需要減一下。但是還是那句話,這他媽的到底是什麼意思阿?
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved