PHP - 计算日期之间的分钟数

时间:2015-02-17 15:54:21

标签: php date logic

我希望创建一个脚本来计算承包商在待机时间内工作了多少小时/分钟。

待机时间显示承包商的默认待机时间。

脚本需要计算承包商在这几个小时内工作的时间。如果工作进入新的一天,它也应该是兼容的(见下面的例子)。

待机时间

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

1 个答案:

答案 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()以秒为单位转换日期,并在两个时间戳之间进行区分。