我从.NET Web服务获得以下XML:
<?xml version="1.0" encoding="utf-8"?>
<DataSet>
<xs:schema id="NewDataSet" xmlns="" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata">
<xs:element name="NewDataSet" msdata:IsDataSet="true">
<xs:complexType>
<xs:choice maxOccurs="unbounded">
<xs:element name="Table1">
<xs:complexType>
<xs:sequence>
<xs:element name="GROUP_ID" type="xs:int" minOccurs="0" />
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:choice>
</xs:complexType>
</xs:element>
</xs:schema>
<diffgr:diffgram xmlns:msdata="urn:schemas-microsoft-com:xml-msdata" xmlns:diffgr="urn:schemas-microsoft-com:xml-diffgram-v1">
<NewDataSet xmlns="">
<Table1 diffgr:id="Table11" msdata:rowOrder="0" diffgr:hasChanges="inserted">
<GROUP_ID>NUM</GROUP_ID>
</Table1>
</NewDataSet>
</diffgr:diffgram>
</DataSet>
我只需要访问GROUP_ID节点值,但想知道最简单的方法。到目前为止,我一直在使用DomDocument
和DomXPath
来查询该节点,但我希望有一种更好的方法可以解决这个问题:
$xml = new DomDocument();
$xml->load('file.xml');
$xp = new DomXPath($xml);
$result = $xp->query('//GROUP_ID');
$id = null;
foreach($result as $node){
$id = $node->nodeValue;
break;
}
谢谢!
答案 0 :(得分:2)
不幸的是,需要以某种方式循环。如果您使用的是simplexml,则可以将代码编写为:
$xml = simplexml_load_file('file.xml');
$result = $xml->xpath('//GROUP_ID');
while(list(,$node) = each($result)) {
$id = (string) $node;
break; // optional
}