我在从数据库中检索日期时创建了这个函数,并以意大利语格式将其回显到屏幕上:
function get_data_ita($date) {
if ($date == "")
return "";
$d = new DateTime($date);
return $d->format('d/m/Y');
}
其中$date
是mysql格式,如:2017-12-31 14:00:00
现在,如果我传递一个正确的格式,比如:2017-12-31 14:00:00
,函数就可以工作了。但有时我需要使用相同的函数,传递一个已经格式化的日期,比如:30/12/2017
。在这种情况下,我当然会得到解析错误。
我如何检查传递的日期是否已经是意大利格式,如果是,则返回未更改的日期,如果不是,则解析该日期?我需要一个类似如下的函数:
function get_data_ita($date) {
if ( $date== ALREADY_IN_ITALIAN_FORMAT )
return $date;
if ($date == "")
return "";
$d = new DateTime($date);
return $d->format('d/m/Y');
}
echo get_data_ita("30/12/2017");
echo get_data_ita("2017-12-31 14:00:00");
回声:
30/12/2017
31/12/2017
更新:我自己找到了解决方案:
function validateDate($date, $format = 'Y-m-d')
{
$d = DateTime::createFromFormat($format, $date);
return $d && $d->format($format) == $date;
}
function get_data_ita($datetime_db) {
if ( validateDate($datetime_db, 'd/m/Y') ) {
return $datetime_db;
}
if ($datetime_db == "")
return "";
$date = new DateTime($datetime_db);
return $date->format('d/m/Y');
}
发布于 2017-12-13 16:48:30
将/
替换为-
<?php
function get_data_ita($date) {
if ($date == ""){
return "";
}
$date = str_replace('/','-',$date);
$d = new DateTime($date);
return $d->format('d/m/Y');
}
echo get_data_ita("30/12/2017");
echo "\n";
echo get_data_ita("2017-12-31 14:00:00");
?>
发布于 2017-12-13 16:55:45
如果日期不是有效的日期格式,则Strtotime返回false。
这适用于您的输入,但如果有其他日期格式则不起作用。
function get_data_ita($date) {
if ($date == "") return "";
If(strtotime($date) !== False){
$d = new DateTime($date);
}Else{
$d = DateTime::createFromFormat('d/m/Y', $date);
}
return $d->format('d/m/Y');
}
echo get_data_ita("30/12/2017");
echo get_data_ita("2017-12-31 14:00:00");
https://stackoverflow.com/questions/47788695
复制相似问题