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 :
Je veux intégrer le contenu du xml en bdd . Pour celà, j'utilise simpleXML pour construire ma requête sql
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>
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 :
j'ai utilisé le même code que pour la récupération de l'id de annonce mais ça ne fonctionne pas.<?xml version="1.0" encoding="ISO-8859-15" ?>
<client code="ag590001">
<annonce id="AAA">
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">
Auriez vous la solution à mon petit soucis ?
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())); } } ...
Partager