我希望创建一个脚本来计算承包商在待机时间内工作了多少小时/分钟。
待机时间显示承包商的默认待机时间。
脚本需要计算承包商在这几个小时内工作的时间。如果工作进入新的一天,它也应该是兼容的(见下面的例子)。
待机时间
Standby Time From (Example: 18:00)
Standby Time To (Example: 06:00)
旅行开始时间
19.30
网站到达时间
20.30
家乡时间
03:30
上面的示例应该返回8小时0分钟STANDBY。我在下面解释了原因。
承包商前往 19.30 工作 承包商在 20.30 到达现场 承包商在 03:30 到达家中。
这意味着承包商在待机时间为19.30 - 03:30(8小时)。
任何帮助表示赞赏:)
修改
我最初使用的是这个脚本,但是当工作时间分为两天时,它就无法运行。
// get travel start timestring
$travel_time = 70200; //19:30 in seconds
// get home time in seconds
$home_time = 12600; //03:30 in seconds
// get standby_from and standby_to in seconds
$standby_from = 64800; // 18:00 in seconds
$standby_to = 21600; // 06:00 in seconds
// check how many seconds we worked during standby hours
for($sec_of_day=$travel_time;$sec_of_day<=$home_time;$sec_of_day++)
{
if($sec_of_day >= $standby_from && $sec_of_day <= $standby_to)
{
$seconds_sb++;
}
}
echo $seconds_sb; // returns how many seconds
答案 0 :(得分:1)
$to_time = strtotime("2008-12-13 10:42:00");
$from_time = strtotime("2008-12-13 10:21:00");
echo round(abs($to_time - $from_time) / 60,2). " minute";
一个简单的例子,您必须使用strtotime()以秒为单位转换日期,并在两个时间戳之间进行区分。