Я пытаюсь преобразовать дату из yyyy-mm-dd
в dd-mm-yyyy
(но не в SQL); однако я не знаю, как функция даты требует метки времени, и я не могу получить метку времени из этой строки.
Как это возможно?
Я пытаюсь преобразовать дату из yyyy-mm-dd
в dd-mm-yyyy
(но не в SQL); однако я не знаю, как функция даты требует метки времени, и я не могу получить метку времени из этой строки.
Как это возможно?
Используйте strtotime()
и date()
:
$originalDate = "2010-03-21";
$newDate = date("d-m-Y", strtotime($originalDate));
(См. Документацию strtotime и date на сайте PHP.)
Обратите внимание, что это было быстрое решение исходного вопроса. Для более обширных преобразований вам действительно следует использовать класс DateTime
для анализа и форматирования :-)
Если вы хотите избежать преобразования 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
?>
Использование:
implode('-', array_reverse(explode('-', $date)));
Без перерасчета даты я не уверен, что это будет иметь большое значение.
$newDate = preg_replace("/(\d+)\D+(\d+)\D+(\d+)/","$3-$2-$1",$originalDate);
Этот код работает для каждого формата даты.
Вы можете изменить порядок замены переменных, таких как $3- $1- $2, из-за вашего старого формата даты.
$timestamp = strtotime(your date variable);
$new_date = date('d-m-Y', $timestamp);
Для получения дополнительной информации см. Документацию для strtotime
.
Или даже короче
$new_date = date('d-m-Y', strtotime(your date variable));
Еще одна неясная возможность:
$oldDate = '2010-03-20'
$arr = explode('-', $oldDate);
$newDate = $arr[2].'-'.$arr[1].'-'.$arr[0];
Я не знаю, буду ли я использовать его, но все же:)
Примечание: поскольку за этот пост-ответ иногда проголосовали, я вернулся сюда, чтобы любезно попросить людей больше не голосовать. Мой ответ древний, не технически правильный, и здесь есть несколько лучших подходов. Я храню его здесь только в исторических целях.
Хотя в документации плохо описана функция 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
Есть два способа реализовать это:
1.
$date = strtotime(date);
$new_date = date('d-m-Y', $date);
2.
$cls_date = new DateTime($date);
echo $cls_date->format('d-m-Y');
Вы можете попробовать функцию strftime()
. Простой пример: strftime($time, '%d %m %Y');
Используйте эту функцию для преобразования из любого формата в любой формат
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);
}
Ниже приведен код 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);
date('m/d/Y h:i:s a',strtotime($val['EventDateTime']));
Для этого конкретного преобразования мы также можем использовать строку формата.
$new = vsprintf('%3$s-%2$s-%1$s', explode('-', $old));
Очевидно, что это не будет работать для многих других преобразований формата даты, но так как мы просто переставляем подстроки в этом случае, это еще один возможный способ сделать это.
Простой способ Используйте 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));
Вы можете изменить формат, используя date() и strtotime().
$ date = '18.09.2009';
дата эха ('d-m-y', strtotime ($ date));
Результат:
18-09-19
Мы можем изменить формат, изменив (д-м-у).