我有这个网址:
返回XML响应,我想直接获取它的值而不循环遍历整个内容,到目前为止,我只访问了$str=$xml->getName();
的XML根节点的名称。那么有什么方法可以访问其余的节点。
以下是从URL返回的示例XML。
<zs:searchRetrieveResponse xmlns:zs="http://www.loc.gov/zing/srw/">
<zs:version>1.1</zs:version>
<zs:numberOfRecords>2</zs:numberOfRecords>
<zs:records>
<zs:record>
<zs:recordSchema>marcxml</zs:recordSchema>
<zs:recordPacking>xml</zs:recordPacking>
<zs:recordData>
<record xmlns="http://www.loc.gov/MARC21/slim">
<leader>01517cam a2200277 i 4500</leader>
<controlfield tag="001">17092185</controlfield>
<controlfield tag="005">20150720141836.0</controlfield>
<controlfield tag="008">111221s2011 caua 000 0 eng</controlfield>
<datafield tag="906" ind1=" " ind2=" ">
<subfield code="a">7</subfield>
<subfield code="b">cbc</subfield>
<subfield code="c">orignew</subfield>
<subfield code="d">1</subfield>
<subfield code="e">ecip</subfield>
<subfield code="f">20</subfield>
<subfield code="g">y-gencatlg</subfield>
</datafield>
</zs:recordData>
<zs:recordPosition>2</zs:recordPosition>
</zs:record>
</zs:records>
<zs:echoedSearchRetrieveRequest>
<zs:version>1.1</zs:version>
<zs:query>bath.isbn=9781452110103</zs:query>
<zs:maximumRecords>10</zs:maximumRecords>
<zs:recordPacking>xml</zs:recordPacking>
<zs:recordSchema>marcxml</zs:recordSchema>
</zs:echoedSearchRetrieveRequest>
</zs:searchRetrieveResponse>
答案 0 :(得分:0)
也许您可以选择将simplexml_load_file与xpath一起使用。
首先,您必须注册namespace。 然后,您可以更改要搜索的内容的xpath表达式。
例如:
$xml = simplexml_load_file("http://lx2.loc.gov:210/lcdb?operation=searchRetrieve&recordSchema=marcxml&version=1.1&maximumRecords=10&query=bath.isbn%3D9781452110103");
$xml->registerXPathNamespace("slim", "http://www.loc.gov/MARC21/slim");
$path = '/zs:searchRetrieveResponse/zs:records/zs:record[1]/zs:recordData/slim:record[1]/slim:datafield[1]/slim:subfield[@code="c"]';
$result = $xml->xpath($path)[0];
echo $result;
将导致:
orignew