我尝试了这段代码,它会给我正确的日期,但时间不正确:
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
所以订单不正确。在时间部分我有问题。怎么解决这个问题?
答案 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;
答案 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年。