我们有Moodle插件,我们在这里添加每位员工的旅行时间.
到目前为止,我们以天为单位计算了旅行时间的持续时间,因为我们仅以时间表 – 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的小时和分钟的准确时间.
如何计算出行时间并以天数和半天显示(我们假设半天是从8小时工作日起4小时.
因此,我们将显示0,5天(s),而不是旅行时间1天(s)添加timepickup- 21.10.2105 08:00 timereturn-23.10.2015 12:00.
最佳答案 像这样的东西可以工作
$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则增加一整天.