Преобразование одного формата даты в другой в 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

Но я, конечно, хотел бы, чтобы он возвращал текущую дату, а не рассвет. Что я делаю неправильно?


person Tom    schedule 30.01.2010    source источник
comment
tech-blog.maddyzone.com/php/type-date-convert- php очень хорошая статья   -  person Rituraj ratan    schedule 27.09.2014
comment
stackoverflow.com/ questions / 2167916 /   -  person Recai    schedule 17.12.2018


Ответы (17)


Второй параметр date() должен быть правильной меткой времени (секунды с 1 января 1970 г.). Вы передаете строку, которую date () не может распознать.

Вы можете использовать strtotime () для преобразования строка даты в метку времени. Однако даже strtotime () не распознает формат y-m-d-h-i-s.

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);   
person Pekka    schedule 30.01.2010
comment
Примечание. Согласно php.net, DateTime существует с PHP 5.2 в ядре PHP, и экспериментальная поддержка DateTime может быть включена для PHP 5.1 при компиляции. secure.php.net/manual/en/datetime.installation.php - person Charlotte Dunois; 14.10.2016

Самый простой способ сделать это

$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');

Этот другой вопрос также относится к той же теме: Преобразовать формат даты гггг-мм-дд =› дд-мм-гггг.

person ceiroa    schedule 11.07.2012
comment
Я отредактировал ответ. Я просто хотел указать, что эти два вопроса должны быть как-то связаны. - person ceiroa; 11.07.2012
comment
$timestring = $now->format('Y-m-d h:i:s'); конечно? m для месяцев, i для минут - person Mark Baker; 02.02.2015
comment
@madlopt ~ статические методы: secure.php.net/manual/en/ language.oop5.static.php - person ceiroa; 29.06.2016
comment
Ты прав. Но он не может создать объект, если дата плохая. - person madlopt; 30.06.2016

Основы

Самый простой способ преобразовать один формат даты в другой - использовать 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() принимает временную метку 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');
person John Conde    schedule 15.04.2014

Попробуй это:

$old_date = date('y-m-d-h-i-s');
$new_date = date('Y-m-d H:i:s', strtotime($old_date));
person Sarfraz    schedule 30.01.2010
comment
Не сработает, strtotime () не распознает формат. Просто попробовал. - person Pekka; 30.01.2010
comment
согласен, я просто ввел код формата от спрашивающего, должен быть указан правильный формат. - person Sarfraz; 30.01.2010

Чтобы преобразовать $date из dd-mm-yyyy hh:mm:ss в правильную дату и время MySQL, я делаю следующее:

$date = DateTime::createFromFormat('d-m-Y H:i:s',$date)->format('Y-m-d H:i:s');
person Jelle de Fries    schedule 04.03.2013
comment
Не следует связывать эти методы в цепочку, если вы не на 110% уверены, что $ date является действительной датой и соответствует формату. При этом будет возвращена недопустимая дата, которая не совсем соответствует формату: Fatal error: Call to a member function format() on a non-object. Просто головы! - person Rob W; 11.04.2014
comment
Правда, лучшее решение - сделать это за 3 шага с нулевой проверкой в ​​качестве среднего шага. - person Jelle de Fries; 18.04.2014

Ниже приводится простой способ конвертировать даты в разные форматы.

// 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";
person Peter    schedule 25.03.2016

$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); 

OR


$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); 
person Rifat    schedule 30.01.2010
comment
Да, конечно, спасибо, это имя файла GUID, которое я хочу преобразовать обратно в правильный формат даты. - person Tom; 30.01.2010
comment
preg_match_all() кажется немного глупым, если вы не зацикливаете его возвращаемое значение. Зачем звонить _all, если вам нужен только один? - person mickmackusa; 09.03.2021

Этот собственный способ поможет преобразовать любой введенный формат в желаемый формат.

$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);
person Nishad Up    schedule 07.02.2018
comment
Я не понимаю, как этот ответ добавляет странице какую-то новую ценность. Есть несколько ответов, которые давали эту технику ГОДОМ ранее. - person mickmackusa; 09.03.2021

Вам необходимо преобразовать $ old_date обратно в метку времени, так как функция даты требует метку времени в качестве второго аргумента.

person John Parker    schedule 30.01.2010

strtotime с этим справится. даты просто не совпадают и все в американском формате.

<?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";
?>
person de_nuit    schedule 23.07.2013

Это решило для меня,

$old = '18-04-2018';
$new = date('Y-m-d', strtotime($old));
echo $new;

Выход: 2018-04-18

person Ashokkumar C    schedule 04.04.2018
comment
Этот необъяснимый ответ полностью игнорирует вопрос ОП. В лучшем случае это правильный ответ на другой вопрос. Этого ответа не должно быть на этой странице - это только раздувает уже раздутую страницу и наносит ущерб опыту исследователя. - person mickmackusa; 09.03.2021

Попробуй это:

$tempDate = explode('-','03-23-15');
$date = '20'.$tempDate[2].'-'.$tempDate[0].'-'.$tempDate[1];
person vineet    schedule 31.03.2015
comment
Этот необъяснимый ответ полностью игнорирует вопрос ОП. В лучшем случае это правильный ответ на другой вопрос. Этого ответа не должно быть на этой странице - это только раздувает уже раздутую страницу и наносит ущерб опыту исследователя. - person mickmackusa; 09.03.2021

Это другой способ конвертировать формат даты

 <?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'; ?>
person Varun Malhotra    schedule 06.06.2017
comment
Это не вход OP. Вы отвечаете на другой вопрос. - person mickmackusa; 09.03.2021

Просто использование строк для меня - хорошее решение, меньше проблем с 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')
person Alejandro Aranda    schedule 30.11.2016

Я знаю, что это старый, но, столкнувшись с поставщиком, который непоследовательно использует 5 разных форматов даты в своих API (и тестовых серверах с различными версиями PHP от 5 до последних 7), я решил написать универсальный конвертер, который работает с множеством версий PHP.

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

Чтобы назвать это:

$TheDateTimeIWant=convertAnyDateTome_toMyDateTime([thedateIhave],[theformatIwant]);

Отправка null для формата заставит функцию вернуть дату и время в Epoch / Unix Time. В противном случае отправьте любую строку формата, которую поддерживает date (), а также с «.u» для миллисекунд (я также обрабатываю миллисекунды, даже если date () возвращает нули).

Вот код:

        <?php   
        function convertAnyDateTime_toMyDateTime($dttm,$dtFormat)
        {
            if (!isset($dttm))
            {
                return "";
            }
            $timepieces = array();
            if (is_numeric($dttm))
            {
                $rettime=$dttm;
            }
            else
            {
                $rettime=strtotime($dttm);
                if (strpos($dttm,".")>0 and strpos($dttm,"-",strpos($dttm,"."))>0)
                {
                    $rettime=$rettime.substr($dttm,strpos($dttm,"."),strpos($dttm,"-",strpos($dttm,"."))-strpos($dttm,"."));
                    $timepieces[1]="";
                }
                else if (strpos($dttm,".")>0 and strpos($dttm,"-",strpos($dttm,"."))==0)
                {               
                    preg_match('/([0-9]+)([^0-9]+)/',substr($dttm,strpos($dttm,"."))." ",$timepieces);
                    $rettime=$rettime.".".$timepieces[1];
                }
            }

            if (isset($dtFormat))
            {
                // RETURN as ANY date format sent
                if (strpos($dtFormat,".u")>0)       // Deal with milliseconds
                {
                    $rettime=date($dtFormat,$rettime);              
                    $rettime=substr($rettime,0,strripos($rettime,".")+1).$timepieces[1];                
                }
                else                                // NO milliseconds wanted
                {
                    $rettime=date($dtFormat,$rettime);
                }
            }
            else
            {
                // RETURN Epoch Time (do nothing, we already built Epoch Time)          
            }
            return $rettime;    
        }
    ?>

Вот несколько примеров вызовов - вы заметите, что он также обрабатывает любые данные часового пояса (хотя, как отмечалось выше, любое время, отличное от GMT, возвращается в вашем часовом поясе).

        $utctime1="2018-10-30T06:10:11.2185007-07:00";
        $utctime2="2018-10-30T06:10:11.2185007";
        $utctime3="2018-10-30T06:10:11.2185007 PDT";
        $utctime4="2018-10-30T13:10:11.2185007Z";
        $utctime5="2018-10-30T13:10:11Z";
        $dttm="10/30/2018 09:10:11 AM EST";

        echo "<pre>";
        echo "<b>Epoch Time to a standard format</b><br>";
        echo "<br>Epoch Tm: 1540905011    to STD DateTime     ----RESULT: ".convertAnyDateTime_toMyDateTime("1540905011","Y-m-d H:i:s")."<hr>";
        echo "<br>Epoch Tm: 1540905011          to UTC        ----RESULT: ".convertAnyDateTime_toMyDateTime("1540905011","c");
        echo "<br>Epoch Tm: 1540905011.2185007  to UTC        ----RESULT: ".convertAnyDateTime_toMyDateTime("1540905011.2185007","c")."<hr>";
        echo "<b>Returned as Epoch Time (the number of seconds that have elapsed since 00:00:00 Thursday, 1 January 1970, Coordinated Universal Time (UTC), minus leap seconds.)";
        echo "</b><br>";
        echo "<br>UTCTime1: ".$utctime1." ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime1,null);
        echo "<br>UTCTime2: ".$utctime2."       ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime2,null);
        echo "<br>UTCTime3: ".$utctime3."   ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime3,null);
        echo "<br>UTCTime4: ".$utctime4."      ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime4,null);
        echo "<br>UTCTime5: ".$utctime5."              ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime5,null);
        echo "<br>NO MILIS: ".$dttm."        ----RESULT: ".convertAnyDateTime_toMyDateTime($dttm,null);
        echo "<hr>";
        echo "<hr>";
        echo "<b>Returned as whatever datetime format one desires</b>";
        echo "<br>UTCTime1: ".$utctime1." ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime1,"Y-m-d H:i:s")."              Y-m-d H:i:s";
        echo "<br>UTCTime2: ".$utctime2."       ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime2,"Y-m-d H:i:s.u")."      Y-m-d H:i:s.u";
        echo "<br>UTCTime3: ".$utctime3."   ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime3,"Y-m-d H:i:s.u")."      Y-m-d H:i:s.u";
        echo "<p><b>Returned as ISO8601</b>";
        echo "<br>UTCTime3: ".$utctime3."   ----RESULT: ".convertAnyDateTime_toMyDateTime($utctime3,"c")."        ISO8601";
        echo "</pre>";

Вот результат:

Epoch Tm: 1540905011                        ----RESULT: 2018-10-30 09:10:11

Epoch Tm: 1540905011          to UTC        ----RESULT: 2018-10-30T09:10:11-04:00
Epoch Tm: 1540905011.2185007  to UTC        ----RESULT: 2018-10-30T09:10:11-04:00
Returned as Epoch Time (the number of seconds that have elapsed since 00:00:00 Thursday, 1 January 1970, Coordinated Universal Time (UTC), minus leap seconds.)

UTCTime1: 2018-10-30T06:10:11.2185007-07:00 ----RESULT: 1540905011.2185007
UTCTime2: 2018-10-30T06:10:11.2185007       ----RESULT: 1540894211.2185007
UTCTime3: 2018-10-30T06:10:11.2185007 PDT   ----RESULT: 1540905011.2185007
UTCTime4: 2018-10-30T13:10:11.2185007Z      ----RESULT: 1540905011.2185007
UTCTime5: 2018-10-30T13:10:11Z              ----RESULT: 1540905011
NO MILIS: 10/30/2018 09:10:11 AM EST        ----RESULT: 1540908611
Returned as whatever datetime format one desires
UTCTime1: 2018-10-30T06:10:11.2185007-07:00 ----RESULT: 2018-10-30 09:10:11              Y-m-d H:i:s
UTCTime2: 2018-10-30T06:10:11.2185007       ----RESULT: 2018-10-30 06:10:11.2185007      Y-m-d H:i:s.u
UTCTime3: 2018-10-30T06:10:11.2185007 PDT   ----RESULT: 2018-10-30 09:10:11.2185007      Y-m-d H:i:s.u
Returned as ISO8601
UTCTime3: 2018-10-30T06:10:11.2185007 PDT   ----RESULT: 2018-10-30T09:10:11-04:00        ISO8601

Единственное, чего нет в этой версии, - это возможность выбрать часовой пояс, в котором должно быть возвращаемое datetime. Первоначально я написал это, чтобы изменить любое datetime на Epoch Time, поэтому мне не нужна была поддержка часовых поясов. Хотя добавить это тривиально.

person Robert Mauro    schedule 01.02.2019
comment
попробуйте это 2018-01-01T01: 30: 25.388940303Z - person Shoaib Rehan; 20.01.2021
comment
@ShoaibRehan, в каком формате это будет? - person Robert Mauro; 21.01.2021

Самый простой и простой способ изменить формат даты в php

В PHP любую дату можно преобразовать в требуемый формат даты, используя различные сценарии, например, чтобы изменить любой формат даты на День, Дата Месяц Год

$newdate = date("D, d M Y", strtotime($date));

Он покажет дату в следующем очень хорошем формате

Пн, 16 ноя 2020

И если у вас также есть время в существующем формате даты, например, если у вас есть формат даты и времени SQL 2020-11-11 22:00:00, вы можете преобразовать его в требуемый формат даты, используя следующий

$newdateformat = date("D, d M Y H:i:s", strtotime($oldateformat));

Дата будет отображаться в следующем удобном формате.

Вс, 15 ноя 2020 16:26:00

person Hassan Qasim    schedule 19.11.2020

Для полноты картины я добавляю ответ, используя библиотеку Carbon, которая очень распространена и используется в больших проектах, таких как фреймворк Laravel.

Углеродный конструктор может передавать строку даты (все, что распознается _ 1_) или _ 2_. Если вы имеете дело со строкой даты, которую нелегко проанализировать, Carbon предоставляет Carbon::createFromFormat() статический метод создания.

$carbon = new Carbon("January 3 2025 4:28 am");
// or
$date = new \DateTime("January 3 2025 4:28 am");
$carbon = new Carbon($date);
// or
$carbon = Carbon::createFromFormat("Y-d-m/H:i", "2025-03-01/04:28");

Теперь, когда у вас есть собственный объект Carbon, вы можете использовать метод Carbon::format() для вывода это в любом формате, который вам нужен:

echo $carbon->format("l jS \\of F Y h:i A");
// Friday 3rd of January 2025 04:28 AM

Существует множество вспомогательных методов для быстрого вывода определенных форматов, таких как Carbon::toDateTimeString(), который выводит данные в формате MySQL.

person miken32    schedule 09.06.2021