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

PHP & Base de données Discussion :

Nettoyer une adresse email [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 97
    Par défaut Nettoyer une adresse email
    Bonjour,
    je recupere des emails de toutes formes genre:
    toto@free.Fr
    mais aussi
    "ToTo le Gros" <toto@free.fr>

    Comment nettoyer la 2ieme pour ne recuperer que toto@free.fr


    Merci pour vos conseils.
    A+
    VooDoo

  2. #2
    Membre éclairé Avatar de Sekigawa
    Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 432
    Par défaut
    Salut,

    Tu peux essayer de faire un "split" sur ta variable.

  3. #3
    Membre émérite Avatar de FCYPBA
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2004
    Messages : 745
    Par défaut
    Salut,

    Une petite regex pour extraire éventuellement l'email entre les <>. Cela permettra plus tard de modifier l'expression régulière pour traiter plus de cas

    on applique la regex, si elle fonctionne, on a dans retour l'email désiré.
    Ensuite, on utilise les fonctions de l'extension filter pour valider ou ici nettoyer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $email = '"ToTo le Gros" <toto@free.fr>';
    if ( preg_match('|<(.*)>|',$email,$retour) ) {
        $email = $retour[1];
    }
    echo filter_var($email,FILTER_SANITIZE_EMAIL);
    S'il y a beaucoup d'emails a traiter on eut ajouter un strpos pour ne pas faire la regex à tous les coups.

  4. #4
    Membre éclairé Avatar de Sekigawa
    Profil pro
    Développeur Web
    Inscrit en
    Mars 2008
    Messages
    432
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mars 2008
    Messages : 432
    Par défaut
    Pas mal j'avou !!

  5. #5
    Membre émérite Avatar de FCYPBA
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    745
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2004
    Messages : 745
    Par défaut
    Pour plus de clarté ( pas vraiment nécessaire ici ), on peut utiliser une syntaxe particulière pour les parenthèses capturantes.

    J'ai découvert cette syntaxe, il y a quelques semaines et je la trouve pratique dans le cas de nombreux masques capturants :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    if ( preg_match('|<(?<email>.*)>|',$email,$retour) ) {
        $email = $retour['email'];
    }
    En gros, on nomme la partie capturante et on retrouve ce nom dans le tableau php

  6. #6
    Membre confirmé
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 97
    Par défaut
    Super Merci bcp les gars!
    Par contre j'avoue que j'ai du mal a lire la derniere synthaxe..
    Mais elle roxe!
    A+
    VooDoo

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

Discussions similaires

  1. [Mail] Envoyer Un Message A Une Adresse Email
    Par kamga dans le forum Langage
    Réponses: 1
    Dernier message: 28/04/2006, 14h19
  2. [FLASH 8] récuperer dans une BDD une adresse email
    Par iceman2001 dans le forum Flash
    Réponses: 4
    Dernier message: 06/04/2006, 17h39
  3. Vérification syntaxique d'une adresse email
    Par Tchupacabra dans le forum Access
    Réponses: 5
    Dernier message: 14/12/2005, 08h35
  4. (msn) validité d'une adresse email
    Par t26 dans le forum Messagerie instantanée
    Réponses: 2
    Dernier message: 10/09/2005, 13h05
  5. [langage] vérifier une adresse email
    Par GMI3 dans le forum Langage
    Réponses: 10
    Dernier message: 19/10/2003, 18h06

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