从PHP中的XML .NET DataSet获取数据

时间:2009-07-21 20:27:52

标签: php xml xpath

我从.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节点值,但想知道最简单的方法。到目前为止,我一直在使用DomDocumentDomXPath来查询该节点,但我希望有一种更好的方法可以解决这个问题:

$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;
}

谢谢!

1 个答案:

答案 0 :(得分:2)

不幸的是,需要以某种方式循环。如果您使用的是simplexml,则可以将代码编写为:

$xml = simplexml_load_file('file.xml');
$result = $xml->xpath('//GROUP_ID');
while(list(,$node) = each($result)) {
    $id = (string) $node;
    break; // optional
}