Подтвердить что ты не робот

Конвертировать формат даты в PHP

Я пытаюсь преобразовать дату из yyyy-mm-dd в dd-mm-yyyy (но не в SQL); однако я не знаю, как функция даты требует метки времени, и я не могу получить метку времени из этой строки.

Как это возможно?

4b9b3361

Ответ 1

Используйте strtotime() и date():

$originalDate = "2010-03-21";
$newDate = date("d-m-Y", strtotime($originalDate));

(См. Документацию strtotime и date на сайте PHP.)

Обратите внимание, что это было быстрое решение исходного вопроса. Для более обширных преобразований вам действительно следует использовать класс DateTime для анализа и форматирования :-)

Ответ 2

Если вы хотите избежать преобразования strtotime (например, strtotime не может проанализировать ваши входные данные), вы можете использовать,

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

Или, что эквивалентно:

$newDateString = date_format(date_create_from_format('Y-m-d', $dateString), 'd-m-Y');

Сначала вы даете ему формат, в котором находится $ dateString. Затем вы сообщаете ему формат, в котором вы хотите, чтобы $ newDateString находился.

Или, если исходный формат всегда "Ymd" (гггг-мм-дд), просто используйте DateTime:

<?php
    $source = '2012-07-31';
    $date = new DateTime($source);
    echo $date->format('d.m.Y'); // 31.07.2012
    echo $date->format('d-m-Y'); // 31-07-2012
?>

Ответ 3

Использование:

implode('-', array_reverse(explode('-', $date)));

Без перерасчета даты я не уверен, что это будет иметь большое значение.

Ответ 4

$newDate = preg_replace("/(\d+)\D+(\d+)\D+(\d+)/","$3-$2-$1",$originalDate);

Этот код работает для каждого формата даты.

Вы можете изменить порядок замены переменных, таких как $3- $1- $2, из-за вашего старого формата даты.

Ответ 5

$timestamp = strtotime(your date variable); 
$new_date = date('d-m-Y', $timestamp);

Для получения дополнительной информации см. Документацию для strtotime.

Или даже короче

$new_date = date('d-m-Y', strtotime(your date variable));

Ответ 6

Еще одна неясная возможность:

$oldDate = '2010-03-20'
$arr = explode('-', $oldDate);
$newDate = $arr[2].'-'.$arr[1].'-'.$arr[0];

Я не знаю, буду ли я использовать его, но все же:)

Ответ 7

Примечание: поскольку за этот пост-ответ иногда проголосовали, я вернулся сюда, чтобы любезно попросить людей больше не голосовать. Мой ответ древний, не технически правильный, и здесь есть несколько лучших подходов. Я храню его здесь только в исторических целях.

Хотя в документации плохо описана функция strtotime, @rjmunro правильно указал на проблему в своем комментарии: она указана в формате ISO даты "ГГГГ-ММ-ДД".

Кроме того, хотя моя функция Date_Converter все еще может работать, я хотел бы предупредить, что ниже могут быть неточные утверждения, поэтому не обращайте на них внимания.

Самый голосующий ответ на самом деле неверен!

В руководстве PHP strtotime здесь говорится, что "функция ожидает получить строку, содержащую формат даты на английском языке". На самом деле это означает, что ожидается американский формат даты в США, такой как "mdY" или "m/d/Y".

Это означает, что дата, указанная как "Ymd", может быть неправильно интерпретирована strtotime. Вы должны предоставить дату в ожидаемом формате.

Я написал небольшую функцию для возврата дат в нескольких форматах. Используйте и изменяйте по желанию. Если кто-нибудь превратит это в класс, я был бы рад, если бы этим поделились.

function Date_Converter($date, $locale = "br") {

    # Exception
    if (is_null($date))
        $date = date("m/d/Y H:i:s");

    # Let go ahead and get a string date in case we've
    # been given a Unix Time Stamp
    if ($locale == "unix")
        $date = date("m/d/Y H:i:s", $date);

    # Separate Date from Time
    $date = explode(" ", $date);

    if ($locale == "br") {
        # Separate d/m/Y from Date
        $date[0] = explode("/", $date[0]);
        # Rearrange Date into m/d/Y
        $date[0] = $date[0][1] . "/" . $date[0][0] . "/" . $date[0][2];
    }

    # Return date in all formats
        # US
        $Return["datetime"]["us"] = implode(" ", $date);
        $Return["date"]["us"]     = $date[0];

        # Universal
        $Return["time"]           = $date[1];
        $Return["unix_datetime"]  = strtotime($Return["datetime"]["us"]);
        $Return["unix_date"]      = strtotime($Return["date"]["us"]);
        $Return["getdate"]        = getdate($Return["unix_datetime"]);

        # BR
        $Return["datetime"]["br"] = date("d/m/Y H:i:s", $Return["unix_datetime"]);
        $Return["date"]["br"]     = date("d/m/Y", $Return["unix_date"]);

    # Return
    return $Return;

} # End Function

Ответ 8

Есть два способа реализовать это:

1.

    $date = strtotime(date);
    $new_date = date('d-m-Y', $date);

2.

    $cls_date = new DateTime($date);
    echo $cls_date->format('d-m-Y');

Ответ 9

Вы можете попробовать функцию strftime(). Простой пример: strftime($time, '%d %m %Y');

Ответ 10

Используйте эту функцию для преобразования из любого формата в любой формат

function reformatDate($date, $from_format = 'd/m/Y', $to_format = 'Y-m-d') {
    $date_aux = date_create_from_format($from_format, $date);
    return date_format($date_aux,$to_format);
}

Ответ 11

Ниже приведен код PHP для генерации даты завтра, используя mktime(), и измените его формат на dd/mm/yyyy, а затем распечатайте его с помощью echo.

$tomorrow = mktime(0, 0, 0, date("m"), date("d") + 1, date("Y"));
echo date("d", $tomorrow) . "/" . date("m", $tomorrow). "/" . date("Y", $tomorrow);

Ответ 12

date('m/d/Y h:i:s a',strtotime($val['EventDateTime']));

Ответ 13

Для этого конкретного преобразования мы также можем использовать строку формата.

$new = vsprintf('%3$s-%2$s-%1$s', explode('-', $old));

Очевидно, что это не будет работать для многих других преобразований формата даты, но так как мы просто переставляем подстроки в этом случае, это еще один возможный способ сделать это.

Ответ 14

Простой способ Используйте strtotime() и date():

$original_dateTime = "2019-05-11 17:02:07"; #This may be database datetime
$newDate = date("d-m-Y", strtotime($original_dateTime));

С течением времени

$newDate = date("d-m-Y h:i:s a", strtotime($original_dateTime));

Ответ 15

Вы можете изменить формат, используя date() и strtotime().

$ date = '18.09.2009';

дата эха ('d-m-y', strtotime ($ date));

Результат:

18-09-19

Мы можем изменить формат, изменив (д-м-у).