24

我正在使用以下脚本从 mysql 数据库中提取日历信息并将其显示在页面上。我正在尝试从标准 Mysql 日期格式重新格式化日期,但是从数据库中检索它时出现以下错误:

Warning: date_format() expects parameter 1 to be DateTime, string given in C:\easyphp\www\twinfocus\managecalendar.php on line 24

Warning: date_format() expects parameter 1 to be DateTime, string given in C:\easyphp\www\twinfocus\managecalendar.php on line 24

Warning: date_format() expects parameter 1 to be DateTime, string given in C:\easyphp\www\twinfocus\managecalendar.php on line 24

Warning: date_format() expects parameter 1 to be DateTime, string given in C:\easyphp\www\twinfocus\managecalendar.php on line 24

数据库(如您所见,日期已正确存储): 在此处输入图像描述

剧本 :

<?php
     $sql2 = <<<SQL
        SELECT *
        FROM `calendar`
    SQL;
    if(!$result2 = $db->query($sql2)){ die('There was an error running the query [' . $db->error . ']');}
    echo '<table class="admintable"> <thead>';
    echo '<tr><th>Client Names</th><th>Email</th><th>Tel</th><th>Wedding Date</th><th>Date Created</th><th>Start Time</th><th>End Time</th><th>Price</th><th>Location</th><th>Other Info</th><th>Edit</th><th>Delete</th></tr></thead>';
    while($row2 = $result2->fetch_assoc()){ 
    $weddingdate = $row2['weddingdate'];
    $formattedweddingdate = date_format($weddingdate, 'd-m-Y');
    echo '<tr><td>'.$row2['name'].'</td><td>'.$row2['email'].'</td><td>'.$row2['tel'].'</td><td style="min-width:70px;">'.$formattedweddingdate.'</td><td style="min-width:70px;">'.$row2['datecreated'].'</td><td>'.$row2['starttime'].'</td><td>'.$row2['endtime'].'</td><td>&pound;'.$row2['price'].'</td><td>'.$row2['location'].'</td><td style="min-width:400px;">'.$row2['otherinfo'].'</td><td><a href="managecalendar.php?&key='.$key.'&editwedding='.$row2['id'].'">Edit</a></td><td><a href="calenderdelete.php?&key='.$key.'&delwedding='.$row2['id'].'">Delete</a></td></tr>';}
    echo '</table>';

?>
4

6 回答 6

32

最好的方法是使用DateTime对象来转换您的日期。

$myDateTime = DateTime::createFromFormat('Y-m-d', $weddingdate);
$formattedweddingdate = $myDateTime->format('d-m-Y');

注意:它将仅支持 PHP 5 >= 5.3.0。

于 2013-03-22T10:24:20.920 回答
25

您需要将 DateTime 对象传递给此函数。见手册: php

string date_format ( DateTime $object , string $format )

您可以尝试使用:

date_format (new DateTime($time), 'd-m-Y');

或者你也可以使用:

$date = date_create('2000-01-01');
echo date_format($date, 'Y-m-d H:i:s');
于 2013-03-22T10:24:10.000 回答
14

你为什么不试试这样:

$Weddingdate = new DateTime($row2['weddingdate']);
$formattedweddingdate = date_format($Weddingdate, 'd-m-Y');

或者你也可以这样做:

$Weddingdate = new DateTime($row2['weddingdate']);
echo $Weddingdate->format('d-m-Y');
于 2013-03-22T10:24:11.047 回答
3

这可能会有所帮助

$formattedweddingdate =date('d-m-Y',strtotime($weddingdate));
于 2020-01-23T10:07:20.857 回答
2

试试这个

$start_date = date_create($_POST['start_date']);
$start_date = date_format($start_date,"Y-m-d H:i:s");
于 2020-01-08T08:02:27.697 回答
0

我已经尝试了 sean662 的第 3 个解决方案并使用存储在 INSERT sql 中的 now() 函数,然后它在 date_create() 函数中的值。之后,变量将通过 date_format() 函数传递,您可以拥有您喜欢的日期顺序。

于 2016-08-30T20:19:16.417 回答