在时间戳和日期时间之间转换

时间:2013-01-24 14:51:58

标签: php date datetime timestamp

我尝试了这段代码,它会给我正确的日期,但时间不正确:

function convert_datetime($str) { 

    list($date, $time) = explode(' ', $str); 
    list($year, $month, $day) = explode('-', $date); 
    list($hour, $minute) = explode(':', $time); 
    $timestamp = mktime($hour, $minute, $year, $month, $day); 
    return $timestamp; 
}  
    if(isset($_POST['submit']))
    {
    $datetime=$_POST['startdate'].' '.$_POST['start_hour'].":".$_POST['start_minute'];
    $timestamp=convert_datetime($datetime);
    echo "DateTime:".$datetime;
    echo " ";
    echo "Timestamp:".$timestamp;
    echo " ";
    $dateandtime = date("Y-m-d H:i", $timestamp);
    echo "converted:".$dateandtime;
    }

输入:2013-1-21 21:51 我会把它拿出来

DateTime:2013-1-21 21:51 Timestamp:1358807073 converted:2013-01-21 22:24

所以订单不正确。在时间部分我有问题。怎么解决这个问题?

3 个答案:

答案 0 :(得分:3)

使用Datetime。它更容易,更准确:

$datetime = DateTime::createFromFormat("Y-m-d H:i", '2013-1-21 21:51');
echo 'Timestamp: ' . $datetime->getTimestamp() . PHP_EOL;
echo 'Datetime: ' . $datetime->format("Y-m-d H:i") . PHP_EOL;

Confirmed working

答案 1 :(得分:2)

您缺少秒参数 - 请参阅mktime on phpdocs。在您的示例中,将为秒提供值2013,当添加到时间时会改变整体结果。

function convert_datetime($str) { 

    list($date, $time) = explode(' ', $str); 
    list($year, $month, $day) = explode('-', $date); 
    list($hour, $minute) = explode(':', $time); 
    $timestamp = mktime($hour, $minute, 0, $year, $month, $day); 
    return $timestamp; 
}

另外,php确实内置了转换功能。请尝试strtotime

答案 2 :(得分:0)

当你打发时间时,将零场放入零场。我相信这需要花费2013秒并使用它来添加2013/60并使用它来增加33分钟的时间。我相信mktime假定缺少字段的当前日期,这就是为什么它仍然在今年的2013年。