<?
// To call the function
$tree = GetXMLTree('collection.xml');
mysql_connect("localhost", "richard", "x");
mysql_select_db("CONTENT");
$added_num = 0;
function GetChildren($vals, &$i)
{
$children = array(); // Contains node data
/* Node has CDATA before it's children */
if (isset($vals[$i]['value']))
$children['VALUE'] = $vals[$i]['value'];
/* Loop through children */
while (++$i < count($vals))
{
switch ($vals[$i]['type'])
{
/* Node has CDATA after one of it's children
(Add to cdata found before if this is the case) */
case 'cdata':
if (isset($children['VALUE']))
$children['VALUE'] .= $vals[$i]['value'];
else
$children['VALUE'] = $vals[$i]['value'];
break;
/* At end of current branch */
case 'complete':
if (isset($vals[$i]['attributes'])) {
$children[$vals[$i]['tag']][]['ATTRIBUTES'] = $vals[$i]['attributes'];
$index = count($children[$vals[$i]['tag']])-1;
if (isset($vals[$i]['value']))
$children[$vals[$i]['tag']][$index]['VALUE'] = $vals[$i]['value'];
else
$children[$vals[$i]['tag']][$index]['VALUE'] = '';
} else {
if (isset($vals[$i]['value']))
$children[$vals[$i]['tag']][]['VALUE'] = $vals[$i]['value'];
else
$children[$vals[$i]['tag']][]['VALUE'] = '';
}
break;
/* Node has more children */
case 'open':
if (isset($vals[$i]['attributes'])) {
$children[$vals[$i]['tag']][]['ATTRIBUTES'] = $vals[$i]['attributes'];
$index = count($children[$vals[$i]['tag']])-1;
$children[$vals[$i]['tag']][$index] = array_merge($children[$vals[$i]['tag']][$index],GetChildren($vals, $i));
} else {
$children[$vals[$i]['tag']][] = GetChildren($vals, $i);
}
break;
/* End of node, return collected data */
case 'close':
return $children;
}
}
}
/* Function will attempt to open the xmlloc as a local file, on fail it will attempt to open it as a web link */
function GetXMLTree($xmlloc)
{
if (file_exists($xmlloc))
$data = implode('', file($xmlloc));
else {
$fp = fopen($xmlloc,'r');
$data = fread($fp, 100000000);
fclose($fp);
}
$parser = xml_parser_create('ISO-8859-1');
xml_parser_set_option($parser, XML_OPTION_SKIP_WHITE, 1);
xml_parse_into_struct($parser, $data, $vals, $index);
xml_parser_free($parser);
$tree = array();
$i = 0;
if (isset($vals[$i]['attributes'])) {
$tree[$vals[$i]['tag']][]['ATTRIBUTES'] = $vals[$i]['attributes'];
$index = count($tree[$vals[$i]['tag']])-1;
$tree[$vals[$i]['tag']][$index] = array_merge($tree[$vals[$i]['tag']][$index], GetChildren($vals, $i));
}
else
$tree[$vals[$i]['tag']][] = GetChildren($vals, $i);
return $tree;
}
foreach ($tree["COLLECTION"][0]["DVD"] as $num => $dvd_info) {
// read stuff from array etc....
}
// do stuff with teh variables...
};
?>
Some fields removed to stop the mother of all code dumps.
<?xml version="1.0" encoding="us-ascii"?>
<!-- DVD Profiler Version 2.2.0 Collection Export -->
<!-- Exported: 09/05/2004 19:02:14 -->
<Collection>
<DVD>
<ID>0000000100</ID>
<UPC>00000-00100</UPC>
<Title>Pirates of the Caribbian</Title>
<SortTitle>Pirates of the Caribbian</SortTitle>
<Regions>
<Region>1</Region>
</Regions>
<CollectionType>Owned</CollectionType>
<Rating>PG-13</Rating>
<ProductionYear>2003</ProductionYear>
<Released>2003-12-02</Released>
<RunningTime>143</RunningTime>
<Genres>
<Genre>Adventure</Genre>
</Genres>
</DVD>
</Collection>