it-swarm.com.ru

Преобразовать формат даты гггг-мм-дд => дд-мм-гггг

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

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

441
matthy

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

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

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

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

971
richsage

Если вы хотите избежать преобразования 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 находился.

Или, если исходным форматом всегда является "Y-m-d" (гггг-мм-дд), тогда просто используйте 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
?>
251
ceiroa

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

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

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

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

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

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

33
Alper Sarı

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

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

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

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

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

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

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

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

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

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

Самый проголосовавший ответ на самом деле неверный!

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

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

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

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

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

    # Let's 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
17
Igor Donin

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

1.

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

2.

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

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

9
Sinan

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

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);
}
8
Juancho Ramone

Ниже приведен 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);
7
Vishnu
date('m/d/Y h:i:s a',strtotime($val['EventDateTime']));
5
AbdulBasit

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

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

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

0
Don't Panic

Простой способ Используйте 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));
0
Sani Kamal