XML -> TABLEAU ASSOCIATIF

Utilisateur anonyme - 31 janv. 2006 à 17:35
BiBi FocK Messages postés 10 Date d'inscription lundi 19 juillet 2004 Statut Membre Dernière intervention 25 août 2008 - 6 févr. 2006 à 13:33
Cette discussion concerne un article du site. Pour la consulter dans son contexte d'origine, cliquez sur le lien ci-dessous.

https://codes-sources.commentcamarche.net/source/35727-xml-tableau-associatif

BiBi FocK Messages postés 10 Date d'inscription lundi 19 juillet 2004 Statut Membre Dernière intervention 25 août 2008
6 févr. 2006 à 13:33
Merci beaucoup pour ton code.

Pour ma part je me suis servi de cette fonction seulement pour un xml assez simple.

Mais je reconnais que si l'on a un xml assez conséquent cela devient très vite ingérable, et très lourd.
Utilisateur anonyme
31 janv. 2006 à 17:35
Bonjour,

Je te remercie pour ce boulot, on sait tous que c'est galere de se lancer dans le parsing xml.
J'ai pu tester ta fonction, et ca fonctionne tres bien si on utilise un xml tres (TRES) simple du style :
$xml = "<xml><login gender='male'>Vince</login><login gender='female'>Maya</login></xml>";

Une fois que l'on veut entrer dans une structure plus realiste, ca devient ingérable, des valeurs se perdent et la structure tableau est incohérente.

J'ai tenté avec une structure xml semblable :
$xml = "<xml>

<gender>female</gender>


<gender>male</gender>

<message sender='vince'>coucou maya, tu vas bien?</message>
<xml>";
et puis le tableau me met les valeurs a gauche et a droite.
---------------------
Je me suis permis pour tester de modifier l'introduction de la fonction. Je te fais passer ma réecriture simplifiée.

<?php
function xml2array($xml,$depth){
$xp = xml_parser_create();
xml_parser_set_option($xp, XML_OPTION_CASE_FOLDING, false);
xml_parser_set_option($xp, XML_OPTION_SKIP_WHITE, true);
xml_parse_into_struct($xp,$xml,$val,$index);
xml_parser_free($xp);
for($compteur=0;$depth<count($val);$i){
$v = $val[$depth++];
switch($v['type']){
case "complete":
$tab[$v['tag']][$compteur]['value'] = $v['value'];
$tab[$v['tag']][$compteur++]['attributes'] = $v['attributes'];
break;
case "open":
$tab[$v['tag']][$compteur]['value'] = xml2array($val,$depth);
$tab[$v['tag']][$compteur++]['attributes'] = $v['attributes'];
break;
case "close":
return $tab;
}
}
return $tab;
}
// ----Fin de fonction----

// creation du xml
$xml = "<xml><login gender='male'>Vince</login><login gender='female'>Maya</login></xml>";

// Appel a la fonction
$tab = xml2array($xml,1);
// affichage du résultat
print_r($tab);

?>

En te remerciant encore pour le mal donné, j'epsère que ca t'aidera...

Vincent
Rejoignez-nous