Перетворити один формат дати в інший у PHP


336

Чи є простий спосіб перетворити один формат дати в інший формат дати в 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

Але я, звичайно, хотів би, щоб він повернув поточну дату, а не тріщинув світанок. Що я роблю неправильно?



Відповіді:


293

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

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

PHP 5.3 і вище

Використовуйте DateTime::createFromFormat. Це дозволяє вказати точну маску - за допомогою date()синтаксису - для розбору дати вхідних рядків з.

PHP 5.2 і новіші

Вам доведеться розбирати елементи (рік, місяць, день, годину, хвилину, секунду) вручну, використовуючи substr()та передаючи результати mktime (), який створить вам часову позначку.

Але це багато роботи! Я рекомендую використовувати інший формат, який може зрозуміти strroll (). 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);   

Спасибі Пекка, щойно відредагував моє запитання, спробував це, але, здається, це не працює.
Том

Я редагував відповідь, поки ви її прийняли :) Я додав ще кілька прикладів та посилань.
Pekka

Ось, це справді проблема. Це фіксоване ім'я файлу, яке мені потрібно перетворити назад у дату (має бути у такому форматі), тому я розберу вирішення проблеми.
Том

Примітка: За даними php.net DateTimeіснує, оскільки PHP 5.2 в ядрі PHP DateTimeможе підтримуватися експериментальна підтримка для PHP 5.1 при компіляції. secure.php.net/manual/en/datetime.installation.php
Шарлотта Дюнуа

108

Найпростіший спосіб це зробити

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

Ви спочатку надаєте йому формат $ dateString. Потім ви повідомляєте йому той формат, у якому ви хочете знаходити $ newDateString.

Це також дозволяє уникнути використання strtotime, з яким часом може бути важко працювати.

Якщо ви не перетворюєте один формат дати в інший, а просто хочете поточну дату (або дату) у визначеному форматі, то це ще простіше:

$now = new DateTime();
$timestring = $now->format('Y-m-d h:i:s');

Це інше питання також стосується тієї ж теми: Перетворити формат дати yyyy-mm-dd => dd-mm-yyyy .


І як це дублікат, якщо я поставив питання перед тим, на кого ви звертаєтесь?
Том

1
Я відредагував відповідь. Я просто хотів зазначити, що ці два питання треба якось пов’язати.
ceiroa

доступний на сторінці php 5.3+
Zorox

$timestring = $now->format('Y-m-d h:i:s');точно? mмісяцями, iхвилинами
Марк Бейкер

@madlopt ~ статичні методи: secure.php.net/manual/en/language.oop5.static.php
ceiroa

53

Основи

Simplist спосіб перетворити один формат дати в інший для використання 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()повернення помилки, що призведе до того, що ваша дата буде 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);
  • Розділіть підряд на 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');

27

Спробуйте це:

$old_date = date('y-m-d-h-i-s');
$new_date = date('Y-m-d H:i:s', strtotime($old_date));

Не буде працювати, strtotime () не розпізнає формат. Щойно спробував.
Pekka

погодився, я просто помістив у формат код від запитувача, має бути вказаний належний формат.
Сарфраз

Це працювало для мене. Мій $ old_date був приблизно подібний 2012-05-22T19: 16: 37 + 01: 00. Дякую до речі!
VishwaKumar

15

Щоб перетворити $dateз dd-mm-yyyy hh:mm:ssMySQL у відповідний дату, я виглядаю так:

$date = DateTime::createFromFormat('d-m-Y H:i:s',$date)->format('Y-m-d H:i:s');

4
Ви не повинні зв'язувати ці методи, якщо ви не впевнені на 110%, що дата є дійсною датою та не відповідає формату. При цьому , як то кажуть, недійсна дата точно не відповідає формату Поверне: Fatal error: Call to a member function format() on a non-object. Просто голови вгору!
Наполовину божевільний

Правда, краще рішення - зробити це в 3 етапи з нульовою перевіркою як середнім кроком.
Желле де Фріс

11

Нижче наведено простий метод перетворення дат у різні формати.

// 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";

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

Так, обов'язково дякую, це ім'я файлу GUID, яке я хочу перетворити назад у належний формат дати.
Том

8

Цей рідний спосіб допоможе перетворити будь-який введений формат у потрібний формат.

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


7

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";
?>

5

Спробуйте це:

$tempDate = explode('-','03-23-15');
$date = '20'.$tempDate[2].'-'.$tempDate[0].'-'.$tempDate[1];


2

Це інший спосіб конвертувати формат дати

 <?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'; ?>

1

Просто використання рядків для мене - це гарне рішення, менше проблем з 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')

1

Я знаю, що це старе, але, натрапивши на постачальника, який непослідовно використовує 5 різних форматів дати у своїх API (і тестові сервери з різноманітними версіями PHP від ​​5-х до останніх 7-х), я вирішив написати універсальний конвертер, який працює з безліччю версій PHP.

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

Щоб зателефонувати:

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

Якщо надіслати нуль для формату, функція змусить повернути дату в Epoch / Unix Time. В іншому випадку надсилайте будь-який рядок формату, який підтримує дата (), а також ".u" протягом мілісекунд (я також обробляю мілісекунди, навіть якщо дата () повертає нулі).

Ось код:

        <?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

Єдине, що не в цій версії - це можливість вибору часового поясу, в який ви хочете, щоб повернувся час дати. Спочатку я написав це, щоб змінити будь-який час дати на час епохи, тому мені не потрібна підтримка часового поясу. Додавати хоч і банально.

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.