Précédent   Forum des professionnels en informatique > PHP > Langage > Regex
Regex Forum d'entraide sur les expressions rationnelles PHP. Avant de poster -> FAQ regex, Cours de regex et Sources de regex
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 17/01/2012, 13h27   #1
Nouveau Membre du Club
 
Inscription : mars 2007
Messages : 89
Détails du profil
Informations forums :
Inscription : mars 2007
Messages : 89
Points : 36
Points : 36
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 :
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
cedrick21 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/01/2012, 17h46   #2
Membre éclairé
 
Avatar de humitake
 
Homme Olivier
Étudiant
Inscription : novembre 2010
Messages : 303
Détails du profil
Informations personnelles :
Nom : Homme Olivier
Âge : 20
Localisation : France

Informations professionnelles :
Activité : Étudiant

Informations forums :
Inscription : novembre 2010
Messages : 303
Points : 384
Points : 384
Bonjour,

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

Code php :
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.
humitake est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/01/2012, 18h00   #3
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 808
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

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

Informations forums :
Inscription : juin 2008
Messages : 13 808
Points : 35 789
Points : 35 789
Code :
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 !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, 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
Bovino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 17/01/2012, 18h04   #4
Modérateur
 
Inscription : septembre 2010
Messages : 7 219
Détails du profil
Informations forums :
Inscription : septembre 2010
Messages : 7 219
Points : 8 598
Points : 8 598
bon courage
__________________
http://blog.stealth35.com/
stealth35 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 18/01/2012, 08h46   #5
Nouveau Membre du Club
 
Inscription : mars 2007
Messages : 89
Détails du profil
Informations forums :
Inscription : mars 2007
Messages : 89
Points : 36
Points : 36
merci pour votre aide
cedrick21 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 21h36.


 
 
 
 
Partenaires

Hébergement Web