我们有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则增加一整天.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。