2017-10-14 2 views
0

J'ai cette URL:Comment accéder aux valeurs de XML URL directement en utilisant PHP

http://lx2.loc.gov:210/lcdb?operation=searchRetrieve&recordSchema=marcxml&version=1.1&maximumRecords=10&query=bath.isbn%3D9781452110103

qui renvoie une réponse XML, je veux aller chercher ses valeurs directement sans boucle à travers tout le contenu, jusqu'à présent, je Vous n'avez accédé qu'au nom du noeud racine du fichier XML $str=$xml->getName();. Donc, est-il possible d'accéder au reste des nœuds?

Vous trouverez ci-dessous l'exemple de code XML qui obtient des retours de l'URL.

<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

utilisation php XML Parser: - https://www.w3schools.com/php/php_xml_simplexml_read. asp –

+0

Je l'ai déjà fait avec 'simplexml_load_file'. –

+0

Pouvez-vous s'il vous plaît fournir la sortie attendue. – mega6382

Répondre

0

Peut-être est une option pour vous d'utiliser simplexml_load_file avec xpath.

Vous devez d'abord enregistrer le namespace. Vous pouvez ensuite modifier l'expression xpath pour la chose que vous recherchez.

Par exemple:

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

généreront:

orignew

+0

merci beaucoup. Ça a marché comme sur des roulettes. –