嗨,我有一个24小时时间格式的两个变量,想要计算工作小时数。但是我得到了负的错误值
我用的是PHP,下面是我的代码
$endtime = date( 'g:i A', strtotime( $itInfo['endTime'] ) );
$startTime = date( 'g:i A', strtotime( $itInfo['startTime'] ) );
$timeDiff = (strtotime($endtime) - strtotime($startTime))/60/60;
$total = strtotime($endtime) - strtotime($startTime);
$hours = floor($total / 60 / 60);
$minutes = round(($total - ($hours * 60 * 60)) / 60);
echo "FROM ".$itInfo['startTime']." TO ".$itInfo['endTime']." (".$hours.'.'.$minutes."hours)";`
这是输出从22:00到03:00(-19.0小时),这是错误的输出应该是5小时。
试试这个:
$timeDiff = strtotime($itInfo['endTime']) - strtotime($itInfo['startTime']);
echo substr('00'.($timeDiff / 3600 % 24),-2)
.':'. substr('00'.($timeDiff / 60 % 60),-2)
.':'. substr('00'.($timeDiff % 60),-2);
正如其他人所说,最好使用时间戳。但是使用您当前的代码,您应该能够在echo
:
if ($itInfo['startTime'] > $itInfo['endTime']) {
$hours = 24 - $hours;
}
这将是:24 - 19 = 5
。
另外,一定要在您的$total
变量中添加abs()
:
$total = abs(strtotime($endtime) - strtotime($startTime));