【问题标题】:Convert one date format into another in PHP在 PHP 中将一种日期格式转换为另一种日期格式
【发布时间】:2017-08-27 01:21:21
【问题描述】:

有没有一种简单的方法可以在 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

但我当然希望它返回当前日期,而不是黎明时分。我做错了什么?

【问题讨论】:

标签: php date datetime format date-conversion


【解决方案1】:

date() 的第二个参数必须是正确的时间戳(自 1970 年 1 月 1 日以来的秒数)。您正在传递一个字符串,date() 无法识别该字符串。

您可以使用strtotime() 将日期字符串转换为时间戳。但是,即使是 strtotime() 也无法识别 y-m-d-h-i-s 格式。

PHP 5.3 及更高版本

使用DateTime::createFromFormat。它允许您指定一个精确的掩码 - 使用 date() 语法 - 来解析传入的字符串日期。

PHP 5.2 及更低版本

您必须使用substr() 手动解析元素(年、月、日、小时、分钟、秒)并将结果交给mktime(),这将为您构建一个时间戳。

但这是很多工作!我建议使用 strftime() 可以理解的不同格式。 strftime() 理解 any 日期输入短于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】:

您需要将 $old_date 转换回时间戳,因为 date function 需要时间戳作为其第二个参数。

【讨论】:

    【解决方案3】:

    试试这个:

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

    【讨论】:

    • 不起作用,strtotime() 无法识别格式。刚试过。
    • 同意,我只是输入提问者的格式代码,应该指定正确的格式。
    • 这个答案缺少教育解释。
    【解决方案4】:
    $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 文件名,我想将它转换回正确的日期格式。
    • preg_match_all() 如果你不循环它的返回值,似乎有点傻。当你只想要一个时为什么要打电话给_all
    【解决方案5】:

    最简单的方法是

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

    另一个问题也涉及同一主题:Convert date format yyyy-mm-dd => dd-mm-yyyy

    【讨论】:

    • 我已经编辑了回复。我只是想指出这两个问题应该以某种方式联系起来。
    • $timestring = $now->format('Y-m-d h:i:s'); 确定吗? m 几个月,i 几分钟
    • 你是对的。但如果日期不好,它就无法创建对象。
    【解决方案6】:

    $datedd-mm-yyyy hh:mm:ss 转换为适当的 MySQL 日期时间 我是这样去的:

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

    【讨论】:

    • 除非您 110% 确定 $date 是有效日期并且符合格式,否则不应链接这些方法。话虽如此,与格式不完全匹配的无效日期将返回:Fatal error: Call to a member function format() on a non-object。请注意!
    • 没错,更好的解决方案是分 3 步完成,中间步骤为空检查。
    【解决方案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";
    ?>
    

    【讨论】:

      【解决方案8】:

      基础知识

      将一种日期格式转换为另一种日期格式的最简单方法是将strtotime()date() 结合使用。 strtotime() 会将日期转换为 Unix Timestamp。然后可以将该 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() 要求日期位于 valid format 中。未能提供有效格式将导致 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 结尾和/或时​​间戳为 13 个字符长),您需要先将其转换为秒,然后才能将其转换为另一种格式。有两种方法可以做到这一点:

      • 使用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');
      

      【讨论】:

        【解决方案9】:

        试试这个:

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

        【讨论】:

        • 这个无法解释的答案完全忽略了OP的问题。充其量,这是对另一个问题的正确答案。这个答案不应该出现在这个页面上——它只会让已经很臃肿的页面变得臃肿并损害研究人员的体验。
        【解决方案10】:

        以下是将日期转换为不同格式的简单方法。

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

        【讨论】:

          【解决方案11】:

          只使用字符串,对我来说是一个很好的解决方案,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')
          

          【讨论】:

            【解决方案12】:

            这是转换日期格式的另一种方式

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

            【讨论】:

            • 这不是 OP 的输入。您正在回答不同的问题。
            【解决方案13】:

            这种原生方式将有助于将任何输入的格式转换为所需的格式。

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

            【讨论】:

            • 我看不出这个答案如何为页面添加任何新价值。早在几年前就有几个答案给出了这种技术。
            【解决方案14】:

            这为我解决了,

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

            输出:2018-04-18

            【讨论】:

            • 这个无法解释的答案完全忽略了OP的问题。充其量,这是对另一个问题的正确答案。这个答案不应该出现在这个页面上——它只会让已经很臃肿的页面变得臃肿并损害研究人员的体验。
            【解决方案15】:

            我知道这已经过时了,但是,在遇到一家供应商在其 API 中不一致地使用 5 种不同的日期格式(并使用从 5 到最新 7 的各种 PHP 版本测试服务器)时,我决定编写一个适用于无数 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
            

            此版本中唯一没有的是能够选择您希望返回的日期时间所在的时区。最初,我写这个是为了将任何日期时间更改为纪元时间,所以,我不需要时区支持.不过添加起来很简单。

            【讨论】:

            • 试试这个“2018-01-01T01:30:25.388940303Z”
            【解决方案16】:

            在 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

            【讨论】:

              【解决方案17】:

              为了完整起见,我使用 Carbon 库添加了一个答案,该库非常常见,并且在 Laravel 框架等大型项目中使用。

              Carbon constructor 可以传递一个日期字符串(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
              

              有很多辅助方法可以快速输出某些格式,比如Carbon::toDateTimeString()以MySQL格式输出。

              【讨论】:

                猜你喜欢
                • 2011-11-23
                • 1970-01-01
                相关资源
                最近更新 更多