4
下面是我的功能,將採取一個時間戳,告訴你,從現在的23天格式中通過3小時4分6秒可以將我的PHP時間差,功能得到改善呢?
主要的問題是在我的網站我使用MySQL的DATETIME時間而不是TIMESTAMP的所以要使用這個功能我必須將時間值轉換從MySQL到一個時間戳,然後通過我的功能運行。
所以我很好奇,有沒有更好的方式來做到這一點,在一些網頁上,我有100個MySQL的結果,PHP必須100個日期轉換爲時間戳,然後對其中100運行此。
我只是想知道是否有更好的表現方法,請不要推薦所有的PHP框架(Zend公司等)
感謝任何提示/幫助
function duration($timestamp) {
$years = floor($timestamp/(60 * 60 * 24 * 365));
$timestamp %= 60 * 60 * 24 * 365;
$weeks = floor($timestamp/(60 * 60 * 24 * 7));
$timestamp %= 60 * 60 * 24 * 7;
$days = floor($timestamp/(60 * 60 * 24));
$timestamp %= 60 * 60 * 24;
$hrs = floor($timestamp/(60 * 60));
$timestamp %= 60 * 60;
$mins = floor($timestamp/60);
$secs = $timestamp % 60;
$str = "";
if ($years == 1) {
$str .= "{$years} year ";
}elseif ($years > 1) {
$str .= "{$years} yearss ";
}
if ($weeks == 1) {
$str .= "{$weeks} week ";
}elseif ($weeks > 1) {
$str .= "{$weeks} weeks ";
}
if ($days == 1) {
$str .= "{$days} day ";
}elseif ($days > 1) {
$str .= "{$days} days ";
}
if ($hrs == 1) {
$str .= "{$hrs} hour ";
}elseif ($hrs > 1) {
$str .= "{$hrs} hours ";
}
if ($mins == 1) {
$str .= "{$mins} minute ";
}elseif ($mins > 1) {
$str .= "{$mins} minutes ";
}
if ($mins < 1 && $secs >= 1) {
$str .= "{$secs} seconds ";
}
return $str;
}