PHP计算8小时工作日的一半

fre*_*und 5 php mysql moodle

我们有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);
Run Code Online (Sandbox Code Playgroud)

并在此处计算旅行时间:

$datetime1 = strtotime($employee->timepickup);
$datetime2 = strtotime($employee->timereturn);
$interval = $datetime2 - $datetime1;
Run Code Online (Sandbox Code Playgroud)

如您所见,我们添加了选项以导入exact timein hoursminutes中的timepickupand timereturn

如何计算旅行时间并将其显示在dayshalf days(我们假设这half day4 hours8 hour工作日开始)。

因此,而不是旅行时间1 day(s)的增加timepickup- - 21.10.2105 08:00 timereturn23.10.2015 12:00我们将显示0,5 day(s)

Jør*_*n R 3

像这样的东西可以工作

$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;
Run Code Online (Sandbox Code Playgroud)

这有点粗糙,但如果时差的剩余时间为 4.5 小时或更小,则最终会添加半天,如果时差的剩余时间大于 4.5 小时,则最终会添加一整天。