日期格式的PHP日期格式,如“23 Nov,2015 16:44:26 GMT”[复制]

This question already has an answer here:

I am doing scraping and I got a date like 23 Nov, 2015 16:44:26 GMT. I would like to convert it to Y-m-d H:i:s so that I can save it to database datetime field.

I tried like this:

echo date("Y-m-d H:i:s", strtotime("23 Nov, 2015 16:44:26 GMT"));

I have also removed GMT by preg_replace and then

echo date("Y-m-d H:i:s", strtotime("23 Nov, 2015 16:44:26"));

It's giving 1970-01-01 01:00:00

</div>

You can create a DateTime using DateTime::createFromFormat.

For the 'GMT' part from your date, you can use 'T' in the format for the Timezone abbreviation.

$dateTime = DateTime::createFromFormat('d M, Y H:i:s T', '23 Nov, 2015 16:44:26 GMT');

echo $dateTime->format('Y-m-d H:i:s');

Will result in:

2015-11-23 16:44:26

Demo

You can use DateTime::createFromFormat to convert string to DateTime object. http://php.net/manual/en/datetime.createfromformat.php

try this

<?php
$datestr = "23 Nov, 2015 16:44:26 GMT";
$datestr = str_replace(",", "", $datestr);
$dateArray = explode(" ", $datestr) ;
unset($dateArray[count($dateArray)-1]);

$newDateStr = '';
$i=0;
foreach ($dateArray as $dateArrayValue)
{

    $hyphenStr = " ";
    if($i>0 && $i != 3)
    {
       $hyphenStr = "-";  
    }

   $newDateStr .= $hyphenStr.$dateArrayValue ;
   $i++;
}
$newDateStr = trim($newDateStr);

echo date("Y-m-d H:i:s", strtotime($newDateStr));
?>

Also visit : http://php.net/manual/en/function.strtotime.php