提问人:Tom 提问时间:1/30/2010 最后编辑:Ry-Tom 更新时间:4/15/2023 访问量:683303
在PHP中将一种日期格式转换为另一种日期格式
Convert one date format into another in 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
但我当然希望它返回当前日期,而不是黎明。我做错了什么?
答:
第二个参数需要是正确的时间戳(自 1970 年 1 月 1 日以来的秒数)。您正在传递一个字符串,date() 无法识别该字符串。date()
您可以使用 strtotime() 将日期字符串转换为时间戳。但是,即使是 strtotime() 也无法识别该格式。y-m-d-h-i-s
PHP 5.3 及更高版本
使用 DateTime::createFromFormat
。它允许您使用语法指定一个精确的掩码来解析传入的字符串日期。date()
PHP 5.2 及更低版本
您必须手动解析元素(年、月、日、小时、分钟、秒),并将结果交给 mktime(),这将为您构建一个时间戳。substr()
但这是很多工作!我建议使用 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);
评论
DateTime
DateTime
您需要将 $old_date 转换回时间戳,因为 date 函数需要时间戳作为其第二个参数。
试试这个:
$old_date = date('y-m-d-h-i-s');
$new_date = date('Y-m-d H:i:s', strtotime($old_date));
评论
$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);
评论
preg_match_all()
如果你不循环它的返回值,似乎有点傻。当你只想要一个时,为什么要打电话?_all
最简单的方法是
$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。
评论
$timestring = $now->format('Y-m-d h:i:s');
肯定? 几个月,几分钟m
i
转换为正确的 MySQL 日期时间
我是这样说的:$date
dd-mm-yyyy hh:mm:ss
$date = DateTime::createFromFormat('d-m-Y H:i:s',$date)->format('Y-m-d H:i:s');
评论
Fatal error: Call to a member function format() on a non-object
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";
?>
基础知识
将一种日期格式转换为另一种日期格式的简单方法是将 strtotime(
) 与 date()
一起使用。 将日期转换为 Unix 时间戳。然后可以传递该 Unix 时间戳以将其转换为新格式。strtotime()
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'));
请记住,日期必须采用有效格式。未能提供有效格式将导致返回 false,这将导致日期为 1969-12-31。strtotime()
strtotime()
使用 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');
如果您拥有的时间戳以毫秒为单位(可能以 13 个字符结尾和/或时间戳长度为 13 个字符),则需要先将其转换为秒,然后才能将其转换为另一种格式。有两种方法可以做到这一点:000
- 使用
substr()
修剪最后三位数字
修剪最后三位数字可以通过多种方式实现,但使用是最简单的:substr()
$timestamp = substr('1234567899000', -3);
- 将子集除以 1000
您还可以通过将时间戳除以 1000 将时间戳转换为秒。由于时间戳太大,32 位系统无法进行数学运算,因此需要使用 BCMath 库以字符串形式进行数学运算:
$timestamp = bcdiv('1234567899000', '1000');
要获取 Unix 时间戳,您可以使用它返回 Unix 时间戳:strtotime()
$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');
试试这个:
$tempDate = explode('-','03-23-15');
$date = '20'.$tempDate[2].'-'.$tempDate[0].'-'.$tempDate[1];
评论
以下是将日期转换为不同格式的简单方法。
// 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";
对我来说,只使用字符串是一个很好的解决方案,减少了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')
这是转换日期格式的另一种方式
<?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'; ?>
评论
这种本机方式将有助于将任何输入的格式转换为所需的格式。
$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
评论
我知道这已经很老了,但是,在遇到一个供应商在他们的 API 中不一致地使用 5 种不同的日期格式(并使用从 5 年代到最新的 7 年代的各种 PHP 版本测试服务器)时,我决定编写一个通用转换器,适用于无数的 PHP 版本。
此转换器几乎可以接受任何输入,包括任何标准日期时间格式(包括带或不带毫秒)和任何纪元时间表示(包括带或不带毫秒),并将其转换为几乎任何其他格式。
要调用它:
$TheDateTimeIWant=convertAnyDateTome_toMyDateTime([thedateIhave],[theformatIwant]);
为格式发送 null 将使函数返回以 Epoch/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
此版本中唯一没有的是能够选择您希望返回的日期时间所在的时区。最初,我写这篇文章是为了将任何日期时间更改为纪元时间,因此,我不需要时区支持。不过,添加起来微不足道。
评论
在 php 中更改日期格式的最简单和最简单的方法
在PHP中,可以使用不同的场景将任何日期转换为所需的日期格式,例如将任何日期格式更改为日,日期,月,年
$newdate = date("D, d M Y", strtotime($date));
它将以以下非常好的格式显示日期
星期一, 2020年11月16日
如果您也有时间,并且使用现有的日期格式,例如,如果您的日期时间格式为 SQL 2020-11-11 22:00:00,则可以使用以下命令将其转换为所需的日期格式
$newdateformat = date("D, d M Y H:i:s", strtotime($oldateformat));
它将以下外观良好的格式显示日期
周日, 2020年11月15日 16:26:00
为了完整起见,我使用 Carbon 库添加了一个答案,该库非常常见,用于 Laravel 框架等大型项目。
Carbon 构造函数可以传递日期字符串(strtotime(
) 识别的任何内容)或 DateTime
对象。如果您正在处理无法轻松解析的日期字符串,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
有很多辅助方法可以快速输出某些格式,例如以MySQL格式输出的辅助方法。Carbon::toDateTimeString()
php 开发人员的 TestDome 问题:
具有 / 和 - 的有效字符串输出将如下所示
Array
(
[0] => 20201215
[1] => 20161215
)
解决 方案:
$dates = array("2020/12/15","15-12-2016","12023121");
$result = array();
foreach($dates as $date){
$f = explode('/',$date);
$d = explode('-',$date);
if(count($d) == 3){
$myDateTime = DateTime::createFromFormat('d-m-Y', $date);
$result[] = $newDateString = $myDateTime->format('Ymd');
}elseif(count($f) == 3){
$myDateTime = DateTime::createFromFormat('Y/m/d', $date);
$result[] = $newDateString = $myDateTime->format('Ymd');
}
}
评论
h
h
H