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 :

séparer le contenu d'une adresse [RegEx]


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    141
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 141
    Points : 92
    Points
    92
    Par défaut séparer le contenu d'une adresse
    Bonjour,

    j'ai reçu dans un fichier xls un listing d'adresse avec la totalité des informations dans la même colonne (adresse + cp + ville).

    Je dois intégrer ces infos dans ma BDD, cependant j'ai 3 champs séparés (toujours adresse + cp + ville).

    Etant une vraie buse en expressions régulières je voudrais vous demander votre aide pour pouvoir extraire, en php, les 3 éléments de ma colonne adresse.

    Je ne sais pas du tout comment formaliser le fait que je veuille tout ce que se trouve avec un nombre à 5 chiffres (adresse), le nombre à 5 chiffres (code postal) et tout ce qu'il y a après (ville).

    Merci d'avance pour votre aide

    EDIT :

    j'ai réussi à trouver une fonction simple qui m'aide bien mais le seul soucis c'est quelle recrache tous les éléments dans un tableau sauf le code postal
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    $elements = preg_split("/[0-9]{5}+/", "15 RUE DE LA PAIX 75000 PARIS");
    print_r($elements);
     
    //renvoi
    [0] : 15 RUE DE LA PAIX
    [1] : PARIS
    merci d'avance pour votre aide

  2. #2
    Membre confirmé Avatar de humitake
    Homme Profil pro
    Étudiant
    Inscrit en
    Novembre 2010
    Messages
    399
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Novembre 2010
    Messages : 399
    Points : 578
    Points
    578
    Par défaut
    Bonjour,

    Il y a peut être plus simple mais tu peux faire ainsi :

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <?php
    $adresse = "15 RUE DE LA PAIX 75000 PARIS";
    $tab = preg_split('([0-9]{5})', $adresse, -1, PREG_SPLIT_OFFSET_CAPTURE);
    $cp = substr($adresse, $tab[1][1] - 6, 6);
    echo 'adresse : ' . $tab[0][0] . '<br />
          cp : ' . $cp . '<br />
          ville : ' . $tab[1][0];
    ?>

    C'est la même fonction que celle que tu as utilisé sauf qu'on lui demande de renvoyer en plus la position de l’élément dans la tableau.
    Il suffit ensuite de découper la chaîne avec ces positions pour récupérer le code postale.

  3. #3
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <?php
    	$adresse = '15 RUE DE LA PAIX 75000 PARIS';
    	preg_match("/^(.*)(\d{5})(.*)$/", $adresse, $elems);
    	var_dump($elems);
    ?>
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  4. #4
    Expert éminent sénior

    Profil pro
    Inscrit en
    Septembre 2010
    Messages
    7 920
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2010
    Messages : 7 920
    Points : 10 726
    Points
    10 726
    Par défaut
    bon courage

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    141
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 141
    Points : 92
    Points
    92
    Par défaut
    merci pour votre aide

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

Discussions similaires

  1. Séparer le contenu d'une liste par une virgule
    Par arngrimur dans le forum C#
    Réponses: 5
    Dernier message: 27/09/2011, 10h02
  2. [Toutes versions] séparer le contenu d'une cellule a partir d'un terme spécifique
    Par thirdeye dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 16/09/2010, 18h00
  3. Réponses: 5
    Dernier message: 27/05/2008, 06h06
  4. Séparer en 3 ligne une adresse postale
    Par Raph31 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 12/05/2008, 21h06
  5. lire le contenu d'une adresse mémoire avec VB Script
    Par pierre.zelb dans le forum VBScript
    Réponses: 2
    Dernier message: 13/12/2006, 13h32

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