格式化日期时出现问题

时间:2009-05-19 01:58:36

标签: php mysql datetime mktime

我正在尝试编写一个函数来为我格式化日期和时间。我有一个几乎相同的功能,只格式化日期。该功能正常。我刚刚添加了一些代码,试着让它用时间格式化日期。它应该返回类似“2009年5月18日晚上9点50分”的内容,但我收到了这个警告:

Warning: mktime() expects parameter 6 to be long, string given in
public_html/include/functions.php on line 421

这是我的代码:

function dateTimeFormat($dateIn)
{
   $x = explode(" ",$dateIn);
   $y = explode("-",$x[0]);
   $z = explode(":",$x[1]);

   $year = $y[0]; 
   $month = $y[1];
   $day = $y[2];
   $hour = $z[0];
   $min = $z[1];

   $dateOut =date("F j, Y h:i A", mktime($hour, $min, 0, $month, $day, $year)); 

   return $dateOut;
}

它的推出也是错误的。它推出:

December 31, 1969 07:00 PM

但数据库中的时间戳是

2009-05-18 05:07:39

1 个答案:

答案 0 :(得分:4)

PHP已经有一个非常好的日期解析功能:strtotime()。它返回一个Unix时间戳,您可以将其传递给date()

换句话说,您的功能可以简化为:

function dateTimeFormat($dateIn)
{
    return date("F j, Y h:i A", strtotime($dateIn));
}