我们有Moodle
plugin
,其中我们添加每个员工的travel time
。到目前为止,我们在days
中计算了旅行时间的持续时间,因为我们只以timepickup
-21.10.2105 timereturn
-23.10.2015的形式添加了每个员工的数据。
数据被添加到这里的函数中:
$user->timepickup = gmdate("Y-m-d H:i", $timepickup);
$user->timereturn = gmdate("Y-m-d H:i", $timereturn);
以及旅行时间的计算:
$datetime1 = strtotime($employee->timepickup);
$datetime2 = strtotime($employee->timereturn);
$interval = $datetime2 - $datetime1;
如您所见,我们在timepickup
和timereturn
的hours
和minutes
中添加了导入exact time
的选项。
如何计算旅行时间并将其显示在days
和half days
中(我们假设half day
是8 hour
工作日的4 hours
。
因此,我们将显示0,5 day(s)
,而不是添加timepickup
-21.10.2105 08:00
timereturn
-23.10.2015 12:00
的行程时间1 day(s)
。
类似的东西可以在中工作
$pickup = strtotime($employee->timepickup);
$return = strtotime($employee->timereturn);
$timediff = ($return - $pickup) / 3600;
$days = floor($timediff / 8);
$halfday = ($timediff - $days * 8) / 4.5;
$days += $halfday < 1 ? 0.5: 1;
这有点粗糙,但如果剩余时间差在4.5小时或更短,你最终会加半天,如果剩余时间大于4.5,你会加一整天。