我有一个PHP脚本,该脚本从远程服务器提取XML文件,并使用simplexml_load_string和json_encode将其转换为JSON.但是,simplexml_load_string似乎忽略了内联属性,如下所示:
<AxisFeedrate dataItemId="iid7" timestamp="2012-03-21T15:15:41-04:00" sequence="7" name="Yfrt" subType="ACTUAL" units="MILLIMETER/SECOND">UNAVAILABLE</AxisFeedrate>
在这种情况下,JSON表示形式为{AxisFeedrate:’UNAVAILABLE’}
但是,我需要使那些属性可用.我一直在想的一个想法是替换字符串以将属性变成文本节点,如下所示:
<AxisFeedrate>
<dataItemId>iid7</dataItemId>
<timestamp>2012-03-21T15:15:41-04:00</timestamp>
<sequence>7</sequence>
<name>Yfrt</name>
<subType>ACTUAL</subType>
<units>MILLIMETER/SECOND"</units>
<value>UNAVAILABLE</value>
</AxisFeedrate>
我可以使用常规查找/替换将属性转换为它们自己的标签元素,但是我很难将原始文本值包装在Value标记中,至少使用查找/替换是困难的.
有什么好的方法可以做到这一点?上面的XML块位于不同数据项上许多类似块的中间,因此我不能仅以替换第一个结束>开始.与> …
解决方法:
您可以使用SimpleXML本身来读取属性.
例:
<?PHP
$xml=simplexml_load_string('<AxisFeedrate dataItemId="iid7" timestamp="2012-03-21T15:15:41-04:00" sequence="7" name="Yfrt" subType="ACTUAL" units="MILLIMETER/SECOND">UNAVAILABLE</AxisFeedrate>');
foreach($xml->attributes() as $k=>$v) {
echo $k." -> ".(string)$v."\n";
}
?>
输出:
dataItemId -> iid7
timestamp -> 2012-03-21T15:15:41-04:00
sequence -> 7
name -> Yfrt
subType -> ACTUAL
units -> MILLIMETER/SECOND