IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bibliothèques et frameworks PHP Discussion :

[SimpleXML] Problème pour récupérer l'attribut de la balise principale avec SimpleXML


Sujet :

Bibliothèques et frameworks PHP

  1. #1
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 2
    Points : 1
    Points
    1
    Par défaut [SimpleXML] Problème pour récupérer l'attribut de la balise principale avec SimpleXML
    Bonjour à toutes et tous,

    Je tourne en rond depuis un bon moment pour un problème qui je suis sur doit être tout bête.

    J'ai le xml de forme suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
     
    <?xml version="1.0" encoding="ISO-8859-15" ?>
    <client code="ag590001">
    <annonce id="AAA">
    	<reference>AAA</reference>
    	<titre>AAA</titre>
    	...
    	<photos>
    		<photo>http://www.....jpg</photo>
    	</photos>
    	<bien>
    		<type>AAA</type>
    		...
    		<code_type>AAA</code_type>
    	</bien>
    	<prestation>
    		<type>AAA</type>
    		...
    		<prix>AAA</prix>
    	</prestation>
    </annonce>
     
    <annonce id="BBB">
    	<reference>BBB</reference>
    	<titre>BBB</titre>
    	...
    	<photos>
    		<photo>http://www.....jpg</photo>
    		<photo>http://www.....jpg</photo>
    	</photos>
    	<bien>
    		<type>BBB</type>
    		...
    		<code_type>BBB</code_type>
    	</bien>
    	<prestation>
    		<type>BBB</type>
    		...
    		<prix>BBB</prix>
    	</prestation>
    </annonce>
    </client>
    Je veux intégrer le contenu du xml en bdd . Pour celà, j'utilise simpleXML pour construire ma requête sql

    J'arrive à récupérer l'ensemble des balises ainsi que l'attribut id de <annonce id =""> mais je bute sur l'attribut code de la balise principale client :

    <?xml version="1.0" encoding="ISO-8859-15" ?>
    <client code="ag590001">

    <annonce id="AAA">
    j'ai utilisé le même code que pour la récupération de l'id de annonce mais ça ne fonctionne pas.

    Voici le code qui fonctionne pour la récupération de l'id de <annonce id="zz"> mais qui ne va pas pour le code de <client code ="nnn">

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
     
    <?php ini_set('mysql.trace_mode', true);
    $xml = simplexml_load_file('file.xml');
     
    $table = array(
    	'code'   => 'code', // attribut code de client
    	'annonce_id'   => 'annonce_id', // attribut id de annonce
    	'adresse'   => 'adresse',
    	'web'   => 'web',
    	...
    	'prix'   => 'prix',		
    );
     
     $id=0;
    foreach($xml->annonce as $bien)
    {
        $data = array();
     
    	foreach($xml->annonce[$id]->attributes() as $a => $b)
           {
    	$data[$table['annonce_id']] = sprintf("'%s'", mysql_real_escape_string($b));
    	$id++;
    	}
     
     	   foreach($bien as $key => $value)
      	  {
     	       if(array_key_exists($key, $table))
      	      {
        	        $data[$table[$key]] = sprintf("'%s'", mysql_real_escape_string($value->__toString()));
            }
      	  }   
     
    ...
    Auriez vous la solution à mon petit soucis ?

  2. #2
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 200
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 200
    Points : 8 425
    Points
    8 425
    Billets dans le blog
    17
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $xml = simplexml_load_file('file.xml');
    $code = $xml['code'] ;

  3. #3
    Nouveau Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    J'ai ai honte tellement cela parait simple

    J'ai ainsi pu terminer mon script qui fonctionne à 100%. Une optimisation est sans doute possible, mais ce n'est que secondaire pour le moment.

    Merci beaucoup pour ton aide Seb.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. LDAP - Problème pour récupérer l'uid
    Par sangei dans le forum API standards et tierces
    Réponses: 3
    Dernier message: 16/11/2005, 13h56
  2. Réponses: 10
    Dernier message: 16/11/2005, 08h33
  3. problème pour récupérer une valeur dans ma bd (débutante)
    Par auryn111 dans le forum Langage SQL
    Réponses: 1
    Dernier message: 26/08/2005, 17h49
  4. [TWebbrowser] Probléme pour récupérer la source
    Par Gauth dans le forum Web & réseau
    Réponses: 8
    Dernier message: 09/04/2005, 15h57
  5. Problème pour récupérer la clé primaire
    Par caramel dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 11/04/2003, 13h57

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo