9

有人知道从包含日期格式的日期中获取字符串的方法吗?

<?php
    $date = date ("2009-10-16 21:30:45");

    // smething like this?
    print date_format ($date);
?>

我问这个是因为我想优化我编写的这个函数,通常是从服务器获取具有不同时区的日期,而不做特定的事情

<?php
function get_timezone_offset ($timezone, $date = null, $format = null, $offset_timezone = null) {
    if ($date == null) $date = date ($format);
    if ($offset_timezone == null) $offset_timezone = date_default_timezone_get ();
    if ($format == null) $format = "Y-m-d H:i:s";
    // I'd like to find a way that can avoid me to write $format and get it directly from the date i pass, but I don't know a particular method can do it
    // if ($format == null) $format = date_format ($date);

    $date_time = new DateTime ($date, new DateTimeZone ($offset_timezone));
    $date_time->setTimeZone (new DateTimeZone ($timezone));
    return $date_time->format ($format);
}

print get_timezone_offset ("Europe/Rome");
print get_timezone_offset ("Europe/Rome", date ("Y-m-d H:i:s"));
print get_timezone_offset ("Europe/Rome", date ("Y-m-d H:i:s"), "Y-m-d H:i:s");
print get_timezone_offset ("Europe/Rome", "2009-10-16 21:30:45", "Y-m-d H:i:s", "America/New_York");
?>

出于性能原因,我希望避免使用正则表达式,但我不知道这是否可能

4

5 回答 5

10

您可以使用strtotime将字符串日期转换为时间戳,并随心所欲地使用时间戳。;)

<?php
$date = "2009-10-16 21:30:45";
$ts   = strtotime($date);
echo date('Y-m-d', $ts);
?>
于 2009-12-06T12:49:37.697 回答
6

PHP date() 函数将时间戳格式化为更易读的日期和时间。为您的项目尝试此代码,

 <?php
    $date=date_create('2014-10-20');
    date_time_set($date,12,20,55);
    echo date_format($date,'Y-m-d H:i:s');
    ?>
于 2014-10-19T18:04:36.017 回答
5

据我所知,没有保证向后工作的方法。最好的方法可能是尝试将正则表达式与预期的众所周知的格式(例如\d{2,4}[-/]\d{2}[-/]\d{2}“Ymd”)进行匹配,但我想不出一种简单的方法来进行匹配而不使用正则表达式。您还必须检查解析的格式是否有意义,并且您不能对诸如 2009 年 3 月 2 日这样的模棱两可的日期做太多事情,它可以表示为09/03/02, 2009-03-02, 02/03/09, 03/02/09, 甚至09/02/03

于 2009-12-06T12:54:14.077 回答
4

我知道已经很晚了,但最好这样做:

$date = date("Y-m-d");
于 2015-05-05T12:03:39.717 回答
0

在while循环和双引号中

while($row = mysqli_fetch_assoc($result)) { 
    echo  " Date is:" ".date('d-M-Y H:i',(strtotime($row["Date_column_name"])))." ;
};
于 2021-03-29T08:04:32.470 回答