Подтвердить что ты не робот

Получение разницы во времени между двумя раз в PHP

Возможный дубликат:
Как получить разницу во времени в минутах в PHP

Я работаю над таблицей посещаемости, чтобы рассчитать поздних и очень поздних сотрудников. Я сохраняю время входа в таблицу (Тип: время). Я могу получить время из базы данных, и я хотел бы показать разницу во времени в отдельном столбце.

Например, если сотрудник вошел в систему или перед 09:00:59, тогда его правое время и разность времени должны отображаться как null. Если он входит в систему после времени, то 09:01:00 или позже разница во времени должна быть 00:00:01. Как мудрый мне нужно рассчитать разницу во времени.

Одно время постоянное, т.е. 09:00:59, а другое - я получаю из таблицы базы данных. Необходимо получить разницу между обоими. Я работаю в PHP. Надеюсь, мой вопрос ясен.

Благодарим вас в Advance.

4b9b3361

Ответ 1

Вы можете использовать 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.

Время выполняется в унифицированном формате, так что это просто большое число, показывающее количество секунд с 1 января 1970 00:00:00 GMT

Ответ 2

Вы также можете использовать DateTime класс:

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

Результат:

1 second(s)

Ответ 3

<?php
$start = strtotime("12:00");
$end = // Run query to get datetime value from db
$elapsed = $end - $start;
echo date("H:i", $elapsed);
?>