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 :

Parser données arborescentes avec accolades


Sujet :

Langage PHP

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Parser données arborescentes avec accolades
    Bonjour,

    J'espère être au bon endroit. Ma question est peut-être plus large que les regex mais peut peut-être se résoudre par regex.

    Je voudrais parser une structure arborescente (qui m'est imposée) dont le séparateur est l'accolade. Pas un langage, juste des data. Exemple plus bas.

    Je n'ai pas de compétence en interpréteurs syntaxiques/grammaticaux.
    Je travaille en environnement PHP.
    Je cherche comment faire sans perdre trop de temps :
    - Parser moi même? (je crains d'y laisser du temps et des bugs)
    - Utiliser un outil? Pourriez-vous m'en conseiller un si vous en voyez un adapté?
    - Essayer de convertir mes accolades en xml et utiliser un parser xml?
    - Expressions régulières?

    Merci pour vos retours.

    Un exemple de structure :

    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
    Attribut1 = "toto";
    Attribut2 = "titi";
     
    ListeSousObjets ={
      SousObjet ={
        Attribut = "tata";
      };
      SousObjet ={
        Attribut = "tutu";
      };
    };
     
    ObjetInterne ={
      Attribut = "xxxx";
    };
     
    Attribut3 = "yyyy";

  2. #2
    Expert éminent
    Avatar de Benjamin Delespierre
    Profil pro
    Développeur Web
    Inscrit en
    Février 2010
    Messages
    3 929
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Février 2010
    Messages : 3 929
    Points : 7 762
    Points
    7 762
    Par défaut
    Ta structure est syntaxiquement proche du JSON, au prix de quelques (2) transformations, on peut directement de servir de json_decode.

    Exemple:
    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
    $struct = <<< EOF
    Attribut1 = "toto";
    Attribut2 = "titi";
     
    ListeSousObjets ={
      SousObjet ={
        Attribut = "tata";
      };
      SousObjet ={
        Attribut = "tutu";
      };
    };
     
    ObjetInterne ={
      Attribut = "xxxx";
    };
    EOF;
     
    function parse_custom_structure ($struct) {
      $a = array(';' => ',', '=' => ':', ' :' => ':');
      $b = array('~(\w+):~' => '"$1":', '~,\s*\}~' => '}');
      $struct = str_replace(array_keys($a), $a, $struct);
      $struct = preg_replace(array_keys($b), $b, '{'.$struct.'}');
      return json_decode($struct, true);
    }
     
    var_dump( parse_custom_structure($struct) );
    Resultat:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    array
      'Attribut1' => string 'toto' (length=4)
      'Attribut2' => string 'titi' (length=4)
      'ListeSousObjets' => 
        array
          'SousObjet' => 
            array
              'Attribut' => string 'tutu' (length=4)
      'ObjetInterne' => 
        array
          'Attribut' => string 'xxxx' (length=4)
    La prochaine fois, tu demandera des structures de données que PHP sait interpréter (c'est pourtant pas le choix qui manque: ini, xml, csv, json etc.)

    En revanche, pour les clés identiques, je ne vois pas du tout comment faire...

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Inscrit en
    Septembre 2012
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Septembre 2012
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Merci beaucoup, c'est très prometteur comme solution.
    C'est un peu ce que je cherchais à faire dans le principe sans avoir le recul pour le sortir.
    Chapeau déjà pour la conversion de mon format propriétaire vers JSON en 4 lignes!
    Je vais me renseigner sur JSON.
    Je vais tester sur des jeux de test réels.
    J'essaie de te tenir au courant.

Discussions similaires

  1. [AC-2007] Base avec données arborescentes
    Par Filou07 dans le forum Modélisation
    Réponses: 3
    Dernier message: 31/07/2014, 07h56
  2. [SAX] Parser un document avec SAX et récupérer les données
    Par sperca dans le forum Format d'échange (XML, JSON...)
    Réponses: 2
    Dernier message: 06/12/2009, 14h51
  3. exploiter une base de données excel avec delphi
    Par budylove dans le forum Bases de données
    Réponses: 2
    Dernier message: 01/02/2005, 19h37
  4. Créer un état à source de données multiples avec Delphi5
    Par khenri2 dans le forum Bases de données
    Réponses: 7
    Dernier message: 23/10/2004, 22h15
  5. parser un fichier avec xerces
    Par traiangueul dans le forum XML/XSL et SOAP
    Réponses: 9
    Dernier message: 02/02/2004, 18h14

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