我正在工作表上计算迟到和迟到的员工。我将登录时间存储在表中(类型:时间)。我能够从数据库中获取时间,我想在单独的列中显示时差。
即,如果员工在或之前登录09:00:59,则其正确的时间和时间差应显示为空。如果他在时间之后(即09:01:00或更晚)登录,则时差应为00:00:01。同样明智的是,我需要计算时间差。
09:00:59
09:01:00
00:00:01
一次是恒定的,即,09:00:59另一次是我从数据库表中获得的。需要两者之间的差异。我正在使用PHP。希望我的问题清楚。
先感谢您。
您可以使用strtotime()进行时间计算。这是一个例子:
$checkTime = strtotime('09:00:59'); echo 'Check Time : '.date('H:i:s', $checkTime); echo '<hr>'; $loginTime = strtotime('09:01:00'); $diff = $checkTime - $loginTime; echo 'Login Time : '.date('H:i:s', $loginTime).'<br>'; echo ($diff < 0)? 'Late!' : 'Right time!'; echo '<br>'; echo 'Time diff in sec: '.abs($diff); echo '<hr>'; $loginTime = strtotime('09:00:59'); $diff = $checkTime - $loginTime; echo 'Login Time : '.date('H:i:s', $loginTime).'<br>'; echo ($diff < 0)? 'Late!' : 'Right time!'; echo '<hr>'; $loginTime = strtotime('09:00:00'); $diff = $checkTime - $loginTime; echo 'Login Time : '.date('H:i:s', $loginTime).'<br>'; echo ($diff < 0)? 'Late!' : 'Right time!';
查看已经提出的问题- 如何以分钟为单位获取时差:
从过去的一减去最近的一并除以60。 时间以Unix格式完成,因此它们只是一个很大的数字,显示了格林尼治标准时间1970年1月1日00:00:00起的秒数
从过去的一减去最近的一并除以60。
时间以Unix格式完成,因此它们只是一个很大的数字,显示了格林尼治标准时间1970年1月1日00:00:00起的秒数