如何计算 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
我想得到每个学生的缺勤时间。
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