场景:一条记录被输入到数据库中。
我试图找出以下等式:
- 如何获取自添加记录以来的小时数。
- 如何获取自添加记录以来距离午夜还有多少小时。
鉴于这些时间:
- 日期/时间:2012-08-22 20:11:20
- 时间戳:1345684280
- 今晚午夜:2012-08-23 00:00:00
- 午夜时间戳:1345698000
我觉得我在正确的轨道上。只需要一些适当的数学来进行计算吗?我的数学很糟糕。任何帮助或指导将不胜感激。我不是在找人来帮我完成这个。只是寻找关于我做错了什么的建议,或者我如何能做得更好。也许解释实现我的目标所必需的数学公式。
这是我到目前为止所拥有的:
class tools{
public function __construct(){
}
public function check_time($time, $request){
$time = strtotime($time);
if($request == 'since'){
$theTime = time() - $time;
$prefix = 'Since:';
} elseif($request == 'until'){
$midnight = mktime(0, 0, 0, date('n'), date('j'), date('Y'));
$theTime = $midnight - $time;
$prefix = 'Until:';
}
$tokens = array (
31536000 => 'year',
2592000 => 'month',
604800 => 'week',
86400 => 'day',
3600 => 'hour',
60 => 'minute',
1 => 'second'
);
foreach($tokens as $unit => $text){
if($theTime < $unit) continue;
$duration = floor($theTime / $unit);
return $prefix.' '.$duration.' '.$text.(($duration>1)?'s':'');
}
}
}// EoF tools class
$tools = new tools();
print_r($tools->check_time('2012-08-22 20:11:20', 'since'));
print_r($tools->check_time('2012-08-22 20:11:20', 'until'));