<Vollständige PHP XML - Referenz
Definition und Verwendung
Die xml_parse_into_struct() Funktion parst XML - Daten in ein Array.
Diese Funktion analysiert die XML-Daten in 2-Arrays:
- Wert Array - enthält die Daten aus dem analysierten XML
- Index-Array - enthält Zeiger auf die Position der Werte in dem Wert Array
Diese Funktion liefert 1 bei Erfolg, oder 0 im Fehlerfall.
Syntax
xml_parse_into_struct(parser,xml,value_arr,index_arr)
Parameter | Beschreibung |
---|---|
parser | Erforderlich. Gibt XML-Parser zu verwenden |
xml | Erforderlich. Gibt XML-Daten zu analysieren |
value_arr | Erforderlich. Gibt den Ziel-Array für die XML-Daten |
index_arr | Optional. Gibt das Zielarray für Indexdaten |
Tipps und Hinweise
Note: Die xml_parse_into_struct() Funktion gibt 1 für den Erfolg und 0 für das Scheitern. Dies ist nicht das gleiche wie WAHR und FALSCH.
Beispiel
XML-Datei
<?xml version="1.0" encoding="UTF-8"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
PHP-Code
<?php
//invalid xml file
$xmlfile = 'test.xml';
$xmlparser = xml_parser_create();
// open a file and read data
$fp = fopen($xmlfile, 'r');
$xmldata = fread($fp, 4096);
xml_parse_into_struct($xmlparser,$xmldata,$values);
xml_parser_free($xmlparser);
print_r($values);
?>
Der Ausgang des Code oben wird sein:
Array
(
[0] => Array
(
[tag] => NOTE
[type] => open
[level] => 1
[value] =>
)
[1] => Array
(
[tag] => TO
[type] => complete
[level] => 2
[value] => Tove
)
[2] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[3] => Array
(
[tag] => FROM
[type] => complete
[level] => 2
[value] => Jani
)
[4] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[5] => Array
(
[tag] => HEADING
[type] => complete
[level] => 2
[value] => Reminder
)
[6] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[7] => Array
(
[tag] => BODY
[type] => complete
[level] => 2
[value] => Don't forget me this weekend!
)
[8] => Array
(
[tag] => NOTE
[value] =>
[type] => cdata
[level] => 1
)
[9] => Array
(
[tag] => NOTE
[type] => close
[level] => 1
)
)
<Vollständige PHP XML - Referenz