364

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

しかし、もちろん、夜明けではなく、現在の日付を返すようにしたいと思います。私は何が間違っているのですか?

4

17 に答える 17

313

2番目のパラメーターdate()は適切なタイムスタンプである必要があります(1970年1月1日からの秒数)。date()が認識できない文字列を渡しています。

strtotime()を使用して、日付文字列をタイムスタンプに変換できます。y-m-d-h-i-sただし、strtotime()でさえフォーマットを認識しません。

PHP5.3以降

を使用しDateTime::createFromFormatます。date()構文を使用して、着信文字列の日付を解析するための正確なマスクを指定できます。

PHP5.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);   
于 2010-01-30T13:01:27.387 に答える
120

これを行う最も簡単な方法は

$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

于 2012-07-11T14:58:42.417 に答える
57

基礎

ある日付形式を別の日付形式に変換する簡単な方法は、で使用strtotime()することdate()です。日付をUnixタイムスタンプstrtotime()に変換します。次に、その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を2番目のパラメーターとして受け取り、フォーマットされた日付を返します。

$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文字の場合)、別の形式に変換する前に、タイムスタンプを秒に変換する必要があります。これを行うには2つの方法があります。

  • を使用して最後の3桁をトリミングしますsubstr()

最後の3桁のトリミングはいくつかの方法で実現できますが、使用するsubstr()のが最も簡単です。

$timestamp = substr('1234567899000', -3);
  • substrを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');

非標準であいまいな日付形式での作業

残念ながら、開発者が使用しなければならないすべての日付が標準形式であるとは限りません。幸い、PHP5.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');
于 2014-04-15T14:49:45.353 に答える
29

これを試して:

$old_date = date('y-m-d-h-i-s');
$new_date = date('Y-m-d H:i:s', strtotime($old_date));
于 2010-01-30T13:01:53.337 に答える
15

適切な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');
于 2013-03-04T12:45:00.843 に答える
13

以下は、日付をさまざまな形式に変換する簡単な方法です。

// 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";
于 2016-03-25T09:11:01.613 に答える
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); 
于 2010-01-30T13:08:34.627 に答える
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);
于 2018-02-07T08:38:35.247 に答える
7

日付関数は2番目の引数としてタイムスタンプを必要とするため、$old_dateをタイムスタンプに戻す必要があります。

于 2010-01-30T13:01:44.830 に答える
7

strtotimeはそれを解決します。日付は同じではなく、すべてus形式です。

<?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";
?>
于 2013-07-23T21:10:34.007 に答える
6

これは私のために解決しました、

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

出力:2018-04-18

于 2018-04-04T18:34:55.530 に答える
5

これを試して:

$tempDate = explode('-','03-23-15');
$date = '20'.$tempDate[2].'-'.$tempDate[0].'-'.$tempDate[1];
于 2015-03-31T13:06:44.597 に答える
3

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

于 2020-11-19T07:03:59.093 に答える
2

これは、日付形式を変換できるもう1つの方法です

 <?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'; ?>
于 2017-06-06T07:22:01.503 に答える
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')
于 2016-11-30T20:58:19.280 に答える
1

私はこれが古いことを知っていますが、APIで一貫して5つの異なる日付形式を使用しているベンダー(および5から最新の7までのさまざまなPHPバージョンのテストサーバー)に遭遇したときに、無数のPHPバージョンで動作します。

このコンバーターは、標準の日時形式(ミリ秒ありまたはなしを含む)およびエポック時間表現(ミリ秒ありまたはなしを含む)を含む実質的にすべての入力を受け取り、それを事実上他の形式に変換します。

それを呼び出すには:

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

フォーマットにnullを送信すると、関数はエポック/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

このバージョンにないのは、返される日時を選択する機能だけです。元々、日時をエポックタイムに変更するためにこれを書いたので、タイムゾーンのサポートは必要ありませんでした。ただし、追加するのは簡単です。

于 2019-02-01T20:34:59.913 に答える
0

完全を期すために、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

Carbon::toDateTimeString()MySQL形式で出力するものなど、特定の形式をすばやく出力するためのヘルパーメソッドはたくさんあります。

于 2021-06-09T15:06:59.837 に答える