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

Langage PHP Discussion :

[preg_match_all] Récupérer valeurs dans XML et créer URLs en fonction [RegEx]


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Novembre 2013
    Messages : 5
    Par défaut [preg_match_all] Récupérer valeurs dans XML et créer URLs en fonction


    Voici ce que je veux faire:
    1) je connais une url de la forme http://url_du_site.com/name1.aspx?label=1&lang=1&n=1
    2) lorsque j'ouvre cette page, ça m'affiche un fichier xml de la forme:
    <?xml version="1.0" encoding="UTF-8" ?>
    - <ROOT>
    - <Tag1>
    - <Value1="XXX">
    - <V FieldID="123456" Field2ID="789" ...
    - <V FieldID="234567" Field2ID="678" ...
    - <V FieldID="345678" Field2ID="567" ...
    3) J'aimerais récupérer toutes ces valeurs de FieldID et, pour chaque valeur, ouvrir les liens suivants:
    http://url_du_site.com/name2.aspx?id=123456&lang=1&n=1&diff=1&r=12345678910

    Maintenant, la pratique
    Voici comment je procède:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $url = 'http://url_du_site.com/name1.aspx?label=1&lang=1&n=1';
     $file = file($url);
     $file = preg_replace('#FieldID="(.+)" Field2ID#', "http://url_du_site.com/name2.aspx?id=$1&lang=1&n=1&diff=1&r=12345678910", $file);
    Pour l'instant, j'en suis là, je ne sais pas encore comment je vais faire ma boucle pour récupérer toutes les urls où j'aurais remplacé le $1 par la valeur récupérée dans mon premier lien, mais déjà, ça bloque.
    Voici ce que j'obtiens:
    http://url_du_site.com/name2.aspx?id=123456" Field2ID=...
    Tout ce qui est après le $1 a disparu, ainsi que FieldID=
    Je pensais que le preg_replace marchait de la manière suivante:
    preg_replace('#chaine_à_chercher_de_début(.+)chaine_à_chercher_de_fin#','début_de_ma_nouvelle_chaine$1fin_de_ma_nouvelle_chaine,où_chercher);
    avec (.+) représentant tout ce qu'il y a entre les 2 chaines de caractères définies et $1 représentant, dans la nouvelle chaîne, ce que l'on a trouvé...
    J'ai mis des anti-slashes, j'ai essayé plein de trucs, mais rien ne marche
    Merci par avance de votre aide.

    Michel

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Pour parcourir un XML, il existe des classes faites pour.

    Utiliser une expression régulière reste possible mais c'est un preg_match qu'il te faut : tu ne cherches pas a modifier le XML mais à en extraire des morceaux.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Novembre 2013
    Messages : 5
    Par défaut
    Bonjour sabotage, merci de ta réponse.
    En fait, je suis vraiment débutant, je me suis mis au php/mysql la semaine dernière, en auto-formation et là, je me fais des petits exercices pour valider mes connaissances
    Donc, je ne sais pas trop ce que sont des
    classes faites pour
    J'ai installé wamp, donc j'ai apache, php et mysql où je peux choisir des extensions.
    Sinon, pour en revenir au preg_replace, effectivement, mon but est de récupérer une valeur et de la copier dans un gabarit de lien, toujours le même.
    Mais comme tu le vois sur mon exemple, cette valeur ne se trouve pas entre une balise ouvrante et une balise fermante, elle suit juste un <ID1=" et est avant un ID2=".
    Pour moi, le preg_match, c'est juste vérifier qu'une valeur se trouve bien dans un texte, non? En quoi ça peut m'extraire mes valeurs?
    Merci d'avance

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Regarde la documentation pour l'utilisation complète : http://fr.php.net/preg_match
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Novembre 2013
    Messages : 5
    Par défaut
    Merci bien, en lisant attentivement la doc de preg_match, j'ai compris ce que tu voulais dire!
    J'aurais énormément appris en quelques jours
    Et si j'ai bien compris, c'est même preg_match_all que je dois utiliser, afin de ne pas m'arrêter à la première occurence trouvée, c'est bien ça?


    Michel

  6. #6
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Novembre 2013
    Messages : 5
    Par défaut
    Voici comment j'ai finalement écrit le code pour arriver à mes fins
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    preg_match_all('#FieldID="(.*?)"#',$site,$out); //le $site est la string qui contient le site web en question
    $index = 0;
    while ($index < count($out[0])){
    	echo "http://url_du_site.com/Name2.aspx?id=".$out[1][$index]."&lang=1&n=1&diff=1&r=12345678910<br/>"; //construction de l'url
    	$index ++;
    	}
    J'y aurais passé du temps, mais au moins, j'ai appris

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

Discussions similaires

  1. [RegEx] Récupérer valeur dans HTML avec preg_match_all
    Par cz1702 dans le forum Langage
    Réponses: 2
    Dernier message: 15/08/2012, 20h51
  2. Récupérer valeur dans XML
    Par toss.net dans le forum C#
    Réponses: 2
    Dernier message: 02/08/2009, 17h05
  3. Réponses: 1
    Dernier message: 25/04/2007, 16h23
  4. Récupérer valeur dans une BD
    Par Matmal11 dans le forum Linux
    Réponses: 6
    Dernier message: 05/09/2006, 16h28
  5. Récupérer valeur dans un thread
    Par Nasky dans le forum Concurrence et multi-thread
    Réponses: 3
    Dernier message: 07/06/2006, 21h37

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