php - 格式化日期的问题

标签 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

最佳答案

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

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

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

关于php - 格式化日期的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/880664/

相关文章:

javascript - Express JS REST API 与 MySQL

java - MySQL JDBC over SSL 问题

c++ - 在 C++ 中使用 mktime 的纪元

python - 列表列表中的 datetime 对象 - 如何获得每天的总数?

php - 如何使用 PHP 执行 sed -i '/^MAIL_DRIVER=/s/=.*/=log/' .env 之类的内容来更新 Laravel dotenv 文件中的变量值

php - Drupal Commons 迁移站点 500 错误

php - FFMPEG 不创建缩略图和转换视频

javascript - 使用 PHP 从动态输入字段中捕获数组值并通过电子邮件发送

PHP:foreach msqli_query 问题

java - 使用新的日期时间 API 格式化日期