转换时间戳

时间:2013-02-23 13:11:47

标签: php xml xml-parsing

我对此代码有疑问,我正在从不同的脚本重用它,它是从xml文件读取并从节点转换日期/时间。节点中的日期如下所示,这是与原始脚本的唯一区别:

<od>10:15:41 01/03/13</od>

我以为我已正确修改了它,但它无效:

$_date=$record->getElementsByTagName("od");
$_date=((!empty($_date))?$_date->item(0)->nodeValue:"");
if(strpos($_date,".")!==false)
{
    $_date=substr($_date,0,strpos($_date,"."));
}
$_date=date("H:i:s m/d/Y",strtotime($_date));
$_date.=(trim($_date)!="")?"Z":"";
xmlrpc_set_type($_date, 'datetime');

非常感谢任何帮助。

2 个答案:

答案 0 :(得分:1)

日期/时间10:15:41 01/03/13invalid format

改为使用DateTime::createFromFormat

答案 1 :(得分:0)

strftime可以使用Y-m-d H:i:s格式正常工作,因为它明确无误。

另一方面,它与H:i:s m/d/y混淆,因为它可以解释为H:i:s d/m/Y。想想日期02/03/2013 - m / d / y表明它是2月3日,而d / m / Y表明它是3月2日。

换句话说,为了确保我们每次都能获得正确的约会,我们必须更加具体。 date_create_from_format('H:i:s m/d/y', $_date)将为您提供与正确日期对应的DateTime对象,如果给定的日期确实在&lt; H:i:s m / d / y&#39;格式。

// Retrieve the date string
$_date=$record->getElementsByTagName("od");
$_date=((!empty($_date))?$_date->item(0)->nodeValue:"");

// Standardize it
$_date = get_date( $_date );
$_date .= (trim($_date) != "") ? "Z" : "";
xmlrpc_set_type($_date, 'datetime');



function get_date( $rawDate ) {

    // Clean date string
    if(strpos($rawDate,".")!==false) {
        $rawDate=substr($rawDate,0,strpos($rawDate,"."));
    }


    // Attempt converting from m/d/y AND m/d/Y formats
    $date = date_create_from_format('H:i:s m/d/y', $rawDate);
    if( false === $date ) $date = date_create_from_format('H:i:s m/d/Y', $rawDate);

    if( !empty($date) ) {
        return $date->format('H:i:s m/d/Y'); // Convert the date to a string again
    }


    // If neither works, try using strtotime instead
    $date = @strtotime($rawDate);
    $date = !empty($date) ? date('H:i:s m/d/y', $date) : false;


    return $date;
}

希望有所帮助!