转换
$date_array = explode("/",$date); // split the array
$var_day = $date_array[0]; //day seqment
$var_month = $date_array[1]; //month segment
$var_year = $date_array[2]; //year segment
$new_date_format = "$var_year-$var_day-$var_month"; // join them together
在某些情况下,这可能是更友好的 MySQL 格式。
将用点分隔的日期更改为用斜杠分隔的日期,反之亦然(并反转顺序)
将日期格式从 YYYY/MM/DD 转换为 DD.MM.YYYY(以及从 DD.MM.YYYY 转换为 YYYY/MM/DD)
/**
* @param string $date (d.m.y, y-m-d, y/m/d)
* @return string|bol
*/
function convertDate($date) {
// EN-Date to GE-Date
if (strstr($date, "-") || strstr($date, "/")) {
$date = preg_split("/[\/]|[-]+/", $date);
$date = $date[2].".".$date[1].".".$date[0];
return $date;
}
// GE-Date to EN-Date
else if (strstr($date, ".")) {
$date = preg_split("[.]", $date);
$date = $date[2]."-".$date[1]."-".$date[0];
return $date;
}
return false;
}
date(‘Y-m-d’, strtotime(’23/10/2009′));
implode(‘-‘, array_reverse(explode(‘/’,$date)));
不会有时间戳的 1970 年限制问题。
您在准备数据库日期的最后一行代码是不正确的,因为它将日放在月之前
$new_date_format = “$var_year-$var_day-$var_month”;
应该是
$new_date_format = “$var_year-$var_month-$var_day”;
Fabricio 的答案更优雅,而且运行良好:)
不过,kukat 的是最好的。
谢谢。简单有效 :)
DateTime::createFromFormat(‘d/m/Y’, “21/1/2013”)->format(“Y-m-d”)
/**
* @name 日期格式更改
* @note PHP > 5.3
* @params 日期,源日期格式,目标日期格式
* @use date_change_format()
*/
function date_change_format($setDate, $from=’Y-m-d’, $to=’d/m/Y’) {
if($setDate !=”) {
$date = DateTime::createFromFormat($from, $setDate);
return $date->format($to);
} else {
return ”;
}
}
对我来说,最快的解决方案是使用 strtr 函数
将 dd/mm/yyyy 转换为 yyyy-dd-mm
strtr(‘Y123-Dd-Mm’, ‘Dd.Mm.Y123′, ’27/11/2017’);