Преобразовать дату формата в другой в PHP
есть ли простой способ конвертировать один формат даты в другой формат даты в PHP?
У меня есть это:
$old_date = date('y-m-d-h-i-s'); // works
$middle = strtotime($old_date); // returns bool(false)
$new_date = date('Y-m-d H:i:s', $middle); // returns 1970-01-01 00:00:00
но я, конечно, хотел бы, чтобы он вернул текущую дату, а не Рассвет. Что я делаю не так?
14 ответов
второй параметр date()
должна быть правильная метка времени (секунды с 1 января 1970 года). Вы передаете строку, которую date () не может распознать.
можно использовать strtotime () для преобразования строки даты в метку времени. Однако даже strtotime () не распознает .
PHP 5.3 и до
использовать DateTime::createFromFormat
. Это позволяет указать точную маску-используя date()
синтаксис-для анализа входящих дат строк.
PHP 5.2 и ниже
вам придется разбирать на элементы (год, месяц, день, час, минута, секунда) вручную с помощью substr()
и передать результаты mktime () это построит вам временную метку.
но это много работы! Я рекомендую использовать другой формат, который может понять strftime (). функцию strftime() понимает любой дата ввода коротко о the next time joe will slip on the ice
. например, это работает:
$old_date = date('l, F d y h:i:s'); // returns Saturday, January 30 10 02:06:34
$old_date_timestamp = strtotime($old_date);
$new_date = date('Y-m-d H:i:s', $old_date_timestamp);
самый простой способ сделать это -
$myDateTime = DateTime::createFromFormat('Y-m-d', $dateString);
$newDateString = $myDateTime->format('m/d/Y');
вы сначала даете ему формат $dateString. Потом ты рассказываешь это формат, который вы хотите $newDateString в.
Это также избегает пользы strtotime, которое может быть трудно работать с временами.
Если вы не преобразуете из одного формата даты в другой, а просто хотите текущую дату( или datetime) в определенном формате, то это еще проще:
$now = new DateTime();
$timestring = $now->format('Y-m-d h:i:s');
этот и другие вопрос также относится к той же теме:преобразовать формат даты гггг-ММ-ДД => ДД-ММ-гггг.
Основы
упрощенный способ преобразования одного формата даты в другой-использовать strtotime()
С date()
. strtotime()
преобразует дату в Метка Времени Unix. Эта метка времени Unix может быть передана в date()
преобразовать его в новый формат.
$timestamp = strtotime('2008-07-01T22:35:17.02');
$new_date_format = date('Y-m-d H:i:s', $timestamp);
или как однострочный:
$new_date_format = date('Y-m-d H:i:s', strtotime('2008-07-01T22:35:17.02'));
имейте в виду, что strtotime()
требует, чтобы дата в действующий формат. Неспособность предоставить допустимый формат приведет к strtotime()
возврат false, который приведет к вашей дате 1969-12-31.
используя DateTime()
начиная с PHP 5.2, PHP предложил DateTime()
класс, который предлагает нам более мощные инструменты для работы с датами (и времени). Мы можем переписать приведенный выше код с помощью DateTime()
а так:
$date = new DateTime('2008-07-01T22:35:17.02');
$new_date_format = $date->format('Y-m-d H:i:s');
работа с Unix метки
date()
берет timeatamp Unix в качестве второго параметра и возвращает отформатированную дату для вас:
$new_date_format = date('Y-m-d H:i:s', '1234567890');
DateTime () работает с метками времени Unix, добавляя @
до отметки времени:
$date = new DateTime('@1234567890');
$new_date_format = $date->format('Y-m-d H:i:s');
если метка времени у вас есть в миллисекундах (это может закончиться в 000
и / или метка времени составляет тринадцать символов) вам нужно будет преобразовать его в секунды, прежде чем вы сможете преобразовать его в другой формат. Есть два способы сделать это:
- обрезать последние три цифры с помощью
substr()
обрезка последних трех цифр может быть достигнута несколькими способами, но с помощью substr()
самый простой:
$timestamp = substr('1234567899000', -3);
- разделить substr на 1000
вы также можете преобразовать метку времени в секунды, разделив на 1000. Поскольку метка времени слишком велика для 32-битных систем для выполнения математики, вам нужно будет использовать BCMath библиотека для выполнения математики в виде строк:
$timestamp = bcdiv('1234567899000', '1000');
чтобы получить метку времени Unix вы можете использовать strtotime()
который возвращает метку времени Unix:
$timestamp = strtotime('1973-04-18');
С DateTime () вы можете использовать DateTime::getTimestamp()
$date = new DateTime('2008-07-01T22:35:17.02');
$timestamp = $date->getTimestamp();
если вы используете PHP 5.2, вы можете использовать U
вариант форматирования вместо:
$date = new DateTime('2008-07-01T22:35:17.02');
$timestamp = $date->format('U');
работа с нестандартными и неоднозначный формат даты
к сожалению не все даты, с которыми разработчик должен работать, имеют стандартный формат. К счастью, PHP 5.3 предоставил нам решение для этого. DateTime::createFromFormat()
позволяет нам сообщить PHP, в каком формате находится строка даты, чтобы ее можно было успешно проанализировать в объект DateTime для дальнейших манипуляций.
$date = DateTime::createFromFormat('F-d-Y h:i A', 'April-18-1973 9:48 AM');
$new_date_format = $date->format('Y-m-d H:i:s');
в PHP 5.4 мы получили возможность сделать доступ члена класса на экземпляр был добавлен, который позволяет нам превратить наш DateTime()
код в одну строку:
$new_date_format = (new DateTime('2008-07-01T22:35:17.02'))->format('Y-m-d H:i:s');
$new_date_format = DateTime::createFromFormat('F-d-Y h:i A', 'April-18-1973 9:48 AM')->format('Y-m-d H:i:s');
попробуйте это:
$old_date = date('y-m-d-h-i-s');
$new_date = date('Y-m-d H:i:s', strtotime($old_date));
преобразование $date
С dd-mm-yyyy hh:mm:ss
к правильному MySQL datetime
Я иду так:
$date = DateTime::createFromFormat('d-m-Y H:i:s',$date)->format('Y-m-d H:i:s');
$old_date = date('y-m-d-h-i-s'); // works
вы делаете здесь неправильно, это должно быть
$old_date = date('y-m-d h:i:s'); // works
разделитель время ':'
Я думаю, это поможет...
$old_date = date('y-m-d-h-i-s'); // works
preg_match_all('/(\d+)-(\d+)-(\d+)-(\d+)-(\d+)-(\d+)/', $old_date, $out, PREG_SET_ORDER);
$out = $out[0];
$time = mktime($out[4], $out[5], $out[6], $out[2], $out[3], $out[1]);
$new_date = date('Y-m-d H:i:s', $time);
или
$old_date = date('y-m-d-h-i-s'); // works
$out = explode('-', $old_date);
$time = mktime($out[3], $out[4], $out[5], $out[1], $out[2], $out[0]);
$new_date = date('Y-m-d H:i:s', $time);
ниже приведен простой способ преобразования дат в различные форматы.
// Create a new DateTime object
$date = DateTime::createFromFormat('Y-m-d', '2016-03-25');
// Output the date in different formats
echo $date->format('Y-m-d')."\n";
echo $date->format('d-m-Y')."\n";
echo $date->format('m-d-Y')."\n";
вам нужно преобразовать $old_date обратно в метку времени, как дата требует метки времени в качестве второго аргумента.
strtotime будет работать. даты просто не совпадают и все в us-формате.
<?php
$e1 = strtotime("2013-07-22T12:00:03Z");
echo date('y.m.d H:i', $e1);
echo "2013-07-22T12:00:03Z";
$e2 = strtotime("2013-07-23T18:18:15Z");
echo date ('y.m.d H:i', $e2);
echo "2013-07-23T18:18:15Z";
$e1 = strtotime("2013-07-21T23:57:04Z");
echo date ('y.m.d H:i', $e2);
echo "2013-07-21T23:57:04Z";
?>
попробуйте это:
$tempDate = explode('-','03-23-15');
$date = '20'.$tempDate[2].'-'.$tempDate[0].'-'.$tempDate[1];
этот собственный способ поможет преобразовать любой введенный формат в нужный формат.
$formatInput = 'd-m-Y'; //Give any format here, this would be converted into your format
$dateInput = '01-02-2018'; //date in above format
$formatOut = 'Y-m-d'; // Your format
$dateOut = DateTime::createFromFormat($formatInput, $dateInput)->format($formatOut);
Это решено для меня,
$old = '18-04-2018';
$new = date('Y-m-d', strtotime($old));
echo $new;
выход : 2018-04-18
это другой способ конвертировать формат даты
<?php
$pastDate = "Tuesday 11th October, 2016";
$pastDate = str_replace(",","",$pastDate);
$date = new DateTime($pastDate);
$new_date_format = $date->format('Y-m-d');
echo $new_date_format.' 23:59:59'; ?>
просто используя строки, для меня это хорошее решение, меньше проблем с mysql. Определяет текущий формат и изменяет его при необходимости, это решение только для испанского / французского формата и английского формата, без использования функции PHP datetime.
class dateTranslator {
public static function translate($date, $lang) {
$divider = '';
if (empty($date)){
return null;
}
if (strpos($date, '-') !== false) {
$divider = '-';
} else if (strpos($date, '/') !== false) {
$divider = '/';
}
//spanish format DD/MM/YYYY hh:mm
if (strcmp($lang, 'es') == 0) {
$type = explode($divider, $date)[0];
if (strlen($type) == 4) {
$date = self::reverseDate($date,$divider);
}
if (strcmp($divider, '-') == 0) {
$date = str_replace("-", "/", $date);
}
//english format YYYY-MM-DD hh:mm
} else {
$type = explode($divider, $date)[0];
if (strlen($type) == 2) {
$date = self::reverseDate($date,$divider);
}
if (strcmp($divider, '/') == 0) {
$date = str_replace("/", "-", $date);
}
}
return $date;
}
public static function reverseDate($date) {
$date2 = explode(' ', $date);
if (count($date2) == 2) {
$date = implode("-", array_reverse(preg_split("/\D/", $date2[0]))) . ' ' . $date2[1];
} else {
$date = implode("-", array_reverse(preg_split("/\D/", $date)));
}
return $date;
}
использовать
dateTranslator::translate($date, 'en')