XML -> TABLEAU ASSOCIATIF

Messages postés
5
Date d'inscription
mercredi 14 juillet 2004
Statut
Membre
Dernière intervention
10 octobre 2008
- - Dernière réponse : 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
-
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.
Onanga
Messages postés
5
Date d'inscription
mercredi 14 juillet 2004
Statut
Membre
Dernière intervention
10 octobre 2008
-
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