在PHP中获取两次时间差

Vig*_*nan 26 php mysql time

可能重复:
如何在PHP中获得以分钟为单位的时差

我正在办理出勤表来计算已故员工和已故员工.我将登录时间存储在表中(类型:时间).我能够从数据库中获取时间,我想在单独的列中显示时差.

即,如果员工登录或之前09:00:59,则其正确的时间和时间差异应显示为空.如果他在时间之后登录,09:01:00或者稍后应该是时差00:00:01.同样明智的我需要及时计算差异.

有一次是不变的,也就是09:00:59我从数据库表中得到的另一个.需要在两者之间获得差异.我在PHP工作.希望我的问题很明确.

先感谢您.

Sit*_*thu 24

您可以使用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!';
Run Code Online (Sandbox Code Playgroud)

演示

检查已经提出的问题 - 如何在几分钟内获得时差:

从过去最多的一个减去过去最多的一个并除以60.

时间以unix格式完成,因此它们只是一个大数字,显示从格林威治标准时间1970年1月1日00:00:00开始的秒数

  • 这并非在所有情况下都有效:例如12:15:00和12:15:01 (4认同)
  • 无用的例子.用这个计算检查nonsence(使用你的代码):Time 1:14:31:34 Time 2:16:09:43 Diff:02:38:09 (2认同)

Dro*_*Zko 14

您还可以使用DateTime 类:

$time1 = new DateTime('09:00:59');
$time2 = new DateTime('09:01:00');
$interval = $time1->diff($time2);
echo $interval->format('%s second(s)');
Run Code Online (Sandbox Code Playgroud)

结果:

1 second(s)
Run Code Online (Sandbox Code Playgroud)