Преобразование одного формата даты в другой в 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
Но я бы, конечно, хотел бы вернуть текущую дату, а не рассвет. Что я делаю неправильно?
Ответы
Ответ 1
Второй параметр 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);
Ответ 2
Самый простой способ сделать это -
$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 = > дд-мм-гггг.
Ответ 3
Основы
Простейший способ конвертировать один формат даты в другой - использовать 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 timeatamp в качестве второго параметра и возвращает вам форматированную дату:
$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. Поскольку временная метка слишком велика для 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');
Ответ 4
Попробуйте следующее:
$old_date = date('y-m-d-h-i-s');
$new_date = date('Y-m-d H:i:s', strtotime($old_date));
Ответ 5
Чтобы преобразовать $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');
Ответ 6
$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);
Ответ 7
Ниже приведен простой способ преобразования дат в разные форматы.
// 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";
Ответ 8
Вам нужно преобразовать $ old_date обратно в метку времени, так как функция даты требует временную метку в качестве ее второго аргумента.
Ответ 9
strtotime будет работать так. даты не совпадают и все в формате usb.
<?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";
?>
Ответ 10
Этот родной способ поможет преобразовать любой введенный формат в желаемый формат.
$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);
Ответ 11
Попробуйте следующее:
$tempDate = explode('-','03-23-15');
$date = '20'.$tempDate[2].'-'.$tempDate[0].'-'.$tempDate[1];
Ответ 12
Это решило для меня,
$old = '18-04-2018';
$new = date('Y-m-d', strtotime($old));
echo $new;
Выход: 2018-04-18
Ответ 13
Это другой способ конвертировать формат даты
<?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'; ?>
Ответ 14
Просто используя строки, для меня это хорошее решение, меньше проблем с 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;
}
USE
dateTranslator::translate($date, 'en')
Ответ 15
Я знаю, что это старо, но, столкнувшись с поставщиком, который непоследовательно использует 5 различных форматов даты в своих API (и тестирует серверы с различными версиями PHP от 5 до последних 7), я решил написать универсальный конвертер, который работает с множеством версий PHP.
Этот преобразователь будет принимать практически любой ввод, включая любой стандартный формат даты и времени (в том числе с или без миллисекунд) и любое представление времени эпохи (в том числе с или без миллисекунд), и преобразовывать его практически в любой другой формат.
Чтобы назвать это:
$TheDateTimeIWant=convertAnyDateTome_toMyDateTime([thedateIhave],[theformatIwant]);
Отправка нуля для формата заставит функцию возвращать дату и время в эпоху /Unix. В противном случае отправьте любую строку формата, которую поддерживает 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
Единственное, чего нет в этой версии - это возможность выбора часового пояса, в котором вы хотите, чтобы возвращаемое время и дата находились. Первоначально я написал это, чтобы изменить любое время и дату на Время эпохи, поэтому мне не нужна была поддержка часового пояса. Это просто добавить хотя.