将int 60转换为60分钟的时间值

时间:2013-04-16 11:14:28

标签: php datetime casting

这似乎应该很简单,但我找不到我需要的时间格式。

值来自数据库240.这意味着240分钟。如何将其存储在php变量中,以便php知道它的分钟数。所以稍后在脚本中我可以将它添加到HH:MM值?

(我已编辑下面的代码以反映其中一个答案)

$startTime = new datetime($row['startTime']);  #08:07:00.0000000
$endTime = new datetime($row['endTime']);      #12:10:00.0000000
$everyMinutes = new dateInterval('P'.$row['everyMinutes'].'M'); #60?
$updatedTime = $startTime->add($everyMinutes); # this should read 09:07:00.0000000

$row的日期来自sql。 startTime和endTime是time(7)数据类型

| taskID |    startTime     |     endTime      | freq |
|________|__________________|__________________|______|
|   1    | 08:07:00.0000000 | 12:10:00.0000000 |  60  |
|   2    | 08:10:00.0000000 | 17:40:00.0000000 |  30  |
|   3    | 08:40:00.0000000 | 14:49:00.0000000 |  60  |
|   4    | 08:43:00.0000000 | 14:49:00.0000000 |  60  |
|   5    | 09:05:00.0000000 | 15:05:00.0000000 |  180 |
|   6    | 10:00:00.0000000 | 22:00:00.0000000 |  5   |

使用此代码,我遇到了两个问题之一。使用new datetime()时,引发的错误为Fatal error: Uncaught exception 'Exception' with message 'DateTime::__construct() expects parameter 1 to be string, object given'

如果没有new datetime(),则抛出的错误为Notice: Object of class DateTime could not be converted to int

2 个答案:

答案 0 :(得分:4)

您应该阅读this page

$date = new DateTime($row['startTime']);
$myInterval = new DateInterval('P'.$row['everyMinutes'].'M');
$date->add($myInterval);
echo $date->format('Y-m-d') . "\n";

答案 1 :(得分:0)

使用此功能

function convertToHoursMins($time, $format = '%d:%d') {
settype($time, 'integer');
if ($time < 1) {
    return;
}
$hours = floor($time/60);
$minutes = $time%60;
return sprintf($format, $hours, $minutes);
}

并将时间花在这上面

convertToHoursMins(240);