如何计算 php 中的缺席时间

How Count Absences time in php

我想得到每个学生的缺勤时间。

Exemple :

$student_absence_from_time = 08:00 -> $student_absence_to_time = 10:00 
$student_absence_from_time = 09:00 -> $student_absence_to_time = 10:00 
$student_absence_from_time = 08:00 -> $student_absence_to_time = 09:00`

我想得到 $student_absence_from_time$student_absence_to_time 之间的差异并计算差异以获得每个学生的总缺勤时间 10:00 - 08:00 = 2小时 + 10:00 - 08:00 = 2h + 09:00 - 08:00 = 1 小时 总缺勤时间为 5 小时 谢谢 :)

获取并存储时间戳作为函数 time() 的结果(自 1970 年以来的秒数)而不是文本。这个时间独立于任何时区。 2 个时间戳之间的差异是过去的秒数。使用 date()strftime()(我更喜欢第二个)将时间戳打印为文本。

顺便说一句,UNIX_TIMESTAMP() 是 SQL 等同于 time()

您可以使用strtotime to convert the time and then array-reduce来计算它们。

考虑以下几点:

$arr = array();
$arr[] = array("student_absence_from_time" => "08:00", "student_absence_to_time" => "10:00");
$arr[] = array("student_absence_from_time" => "09:00", "student_absence_to_time" => "10:00");
$arr[] = array("student_absence_from_time" => "08:00", "student_absence_to_time" => "09:00");

function cntAbsence($carry, $item) {
    return $carry +  strtotime($item["student_absence_to_time"]) - strtotime($item["student_absence_from_time"]);
} // adding the different between "from_time" to "to_time"
echo array_reduce($arr, "cntAbsence", 0) / 3600; // time is in second so divided by 3600 to get hours and use 0 as init