mirror of
https://github.com/sigmasternchen/php-doc-en
synced 2025-03-16 17:08:54 +00:00
Documentation and examples of xml_parse_into_struct
git-svn-id: https://svn.php.net/repository/phpdoc/en/trunk@30694 c90b9560-bf6c-de11-be94-00142212c4b1
This commit is contained in:
parent
608459c3e4
commit
88a84a2461
1 changed files with 214 additions and 0 deletions
|
@ -1621,6 +1621,220 @@ $xml_parser->parse("<A ID=\"hallo\">PHP</A>");
|
|||
</refsect1>
|
||||
</refentry>
|
||||
|
||||
<refentry id="function.xml-parse-into-struct">
|
||||
<refnamediv>
|
||||
<refname>xml_parse_into_struct</refname>
|
||||
<refpurpose>Parse XML data into an array structure</refpurpose>
|
||||
</refnamediv>
|
||||
<refsect1>
|
||||
<title>Description</title>
|
||||
<funcsynopsis>
|
||||
<funcprototype>
|
||||
<funcdef>int <function>xml_parse_into_struct</function></funcdef>
|
||||
<paramdef>int <parameter>parser</parameter></paramdef>
|
||||
<paramdef>string <parameter>data</parameter></paramdef>
|
||||
<paramdef>array <parameter>&values</parameter></paramdef>
|
||||
<paramdef>array <parameter>&index</parameter></paramdef>
|
||||
</funcprototype>
|
||||
</funcsynopsis>
|
||||
<para>
|
||||
This function parses an XML file into 2 parallel array
|
||||
structures, one (<parameter>index</parameter>) containing pointers
|
||||
to the location of the appropriate values in the
|
||||
<parameter>values</parameter> array. These last two parameters
|
||||
must be passed by reference.
|
||||
</para>
|
||||
<para>
|
||||
Below is an example that illustrates the internal structure of
|
||||
the arrays being generated by the function. We use a simple
|
||||
<literal>note</literal> tag embeded inside a
|
||||
<literal>para</literal> tag, and then we parse this an print out
|
||||
the structures generated:
|
||||
<informalexample>
|
||||
<programlisting>
|
||||
$simple = "<para><note>simple note</note></para>";
|
||||
$p = xml_parser_create();
|
||||
xml_parse_into_struct($p,$simple,&$vals,&$index);
|
||||
xml_parser_free($p);
|
||||
echo "Index array\n";
|
||||
print_r($index);
|
||||
echo "\nVals array\n";
|
||||
print_r($vals);
|
||||
</programlisting>
|
||||
</informalexample>
|
||||
When we run that code, the output will be:
|
||||
<informalexample>
|
||||
<programlisting>
|
||||
Index array
|
||||
Array
|
||||
(
|
||||
[PARA] => Array
|
||||
(
|
||||
[0] => 0
|
||||
[1] => 2
|
||||
)
|
||||
|
||||
[NOTE] => Array
|
||||
(
|
||||
[0] => 1
|
||||
)
|
||||
|
||||
)
|
||||
|
||||
Vals array
|
||||
Array
|
||||
(
|
||||
[0] => Array
|
||||
(
|
||||
[tag] => PARA
|
||||
[type] => open
|
||||
[level] => 1
|
||||
)
|
||||
|
||||
[1] => Array
|
||||
(
|
||||
[tag] => NOTE
|
||||
[type] => complete
|
||||
[level] => 2
|
||||
[value] => simple note
|
||||
)
|
||||
|
||||
[2] => Array
|
||||
(
|
||||
[tag] => PARA
|
||||
[type] => close
|
||||
[level] => 1
|
||||
)
|
||||
|
||||
)
|
||||
</programlisting>
|
||||
</informalexample>
|
||||
</para>
|
||||
<para>
|
||||
Event-driven parsing (based on the expat library) can get
|
||||
complicated when you have an XML document that is complex.
|
||||
This function does not produce a DOM style object, but it
|
||||
generates structures amenable of being transversed in a tree
|
||||
fashion. Thus, we can create objects representing the data
|
||||
in the XML file easily. Let's consider the following XML file
|
||||
representing a small database of aminoacids information:
|
||||
<example>
|
||||
<title>moldb.xml - small database of molecular information</title>
|
||||
<programlisting>
|
||||
<?xml version="1.0"?>
|
||||
<moldb>
|
||||
|
||||
<molecule>
|
||||
<name>Alanine</name>
|
||||
<symbol>ala</symbol>
|
||||
<code>A</code>
|
||||
<type>hydrophobic</type>
|
||||
</molecule>
|
||||
|
||||
<molecule>
|
||||
<name>Lysine</name>
|
||||
<symbol>lys</symbol>
|
||||
<code>K</code>
|
||||
<type>charged</type>
|
||||
</molecule>
|
||||
|
||||
</moldb>
|
||||
</programlisting>
|
||||
</example>
|
||||
And then code to parse the document and generate the appropriate
|
||||
objects:
|
||||
<example>
|
||||
<title>
|
||||
parsemoldb.php - parses moldb.xml into and array of
|
||||
molecular objects
|
||||
</title>
|
||||
<programlisting role="php">
|
||||
<?
|
||||
|
||||
class AminoAcid {
|
||||
var $name; // aa name
|
||||
var $symbol; // three letter symbol
|
||||
var $code; // one letter code
|
||||
var $type; // hydrophobic, charged or neutral
|
||||
|
||||
function AminoAcid ($aa) {
|
||||
foreach ($aa as $k=>$v)
|
||||
$this->$k = $aa[$k];
|
||||
}
|
||||
}
|
||||
|
||||
function readDatabase($filename) {
|
||||
// read the xml database of aminoacids
|
||||
$data = implode("",file($filename));
|
||||
$parser = xml_parser_create();
|
||||
xml_parser_set_option($parser,XML_OPTION_CASE_FOLDING,0);
|
||||
xml_parser_set_option($parser,XML_OPTION_SKIP_WHITE,1);
|
||||
xml_parse_into_struct($parser,$data,&$values,&$tags);
|
||||
xml_parser_free($parser);
|
||||
|
||||
// loop through the structures
|
||||
foreach ($tags as $key=>$val) {
|
||||
if ($key == "molecule") {
|
||||
$molranges = $val;
|
||||
// each contiguous pair of array entries are the
|
||||
// lower and upper range for each molecule definition
|
||||
for ($i=0; $i < count($molranges); $i+=2) {
|
||||
$offset = $molranges[$i] + 1;
|
||||
$len = $molranges[$i + 1] - $offset;
|
||||
$tdb[] = parseMol(array_slice($values, $offset, $len));
|
||||
}
|
||||
} else {
|
||||
continue;
|
||||
}
|
||||
}
|
||||
return $tdb;
|
||||
}
|
||||
|
||||
function parseMol($mvalues) {
|
||||
for ($i=0; $i < count($mvalues); $i++)
|
||||
$mol[$mvalues[$i]["tag"]] = $mvalues[$i]["value"];
|
||||
return new AminoAcid($mol);
|
||||
}
|
||||
|
||||
$db = readDatabase("moldb.xml");
|
||||
echo "** Database of AminoAcid objects:\n";
|
||||
print_r($db);
|
||||
|
||||
?>
|
||||
</programlisting>
|
||||
</example>
|
||||
After executing <filename>parsemoldb.php</filename>, the variable
|
||||
<varname>$db</varname> contains an array of
|
||||
<classname>AminoAcid</classname> objects, and the output of the
|
||||
script confirms that:
|
||||
<informalexample>
|
||||
<programlisting>
|
||||
** Database of AminoAcid objects:
|
||||
Array
|
||||
(
|
||||
[0] => aminoacid Object
|
||||
(
|
||||
[name] => Alanine
|
||||
[symbol] => ala
|
||||
[code] => A
|
||||
[type] => hydrophobic
|
||||
)
|
||||
|
||||
[1] => aminoacid Object
|
||||
(
|
||||
[name] => Lysine
|
||||
[symbol] => lys
|
||||
[code] => K
|
||||
[type] => charged
|
||||
)
|
||||
|
||||
)
|
||||
</programlisting>
|
||||
</informalexample>
|
||||
</para>
|
||||
</refsect1>
|
||||
</refentry>
|
||||
|
||||
<refentry id="function.xml-parser-free">
|
||||
<refnamediv>
|
||||
<refname>xml_parser_free</refname>
|
||||
|
|
Loading…
Reference in a new issue