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

Python Discussion :

Requête - filtrer sur phone sans points, espaces, tirets ?


Sujet :

Python

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    231
    Détails du profil
    Informations personnelles :
    Âge : 51
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 231
    Points : 203
    Points
    203
    Par défaut Requête - filtrer sur phone sans points, espaces, tirets ?
    Bonjour,

    Je pensais rechercher des contacts par téléphone

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Contact.objects.filter(phone1__icontains=saisie)
    Malheureusement, dans la base de données dont je n'ai pas la main, les numéros de téléphone comporte des espaces, des points, des tirets.
    Après quelques recherches, je ne vois pas comment faire.
    Avez-vous idée ?

  2. #2
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Salut,
    Un numéro de téléphone est une succession de chiffres, les autres caractères ne sont là que pour la mise en forme.
    Tu peux donc les supprimer pour comparer les numéros.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    def sanitize(number):
        return number.replace('.', '').replace('-', '').replace(' ', '')
     
    if sanitize(a) == sanitize(b):
        print('a est identique à b')

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    231
    Détails du profil
    Informations personnelles :
    Âge : 51
    Localisation : France

    Informations forums :
    Inscription : Mars 2005
    Messages : 231
    Points : 203
    Points
    203
    Par défaut
    Merci VinsS

    Je suis parfaitement d'accord mais impossible d'incorporer cette suite de replace pour filtrer une requête ?

    Sinon, vais garder cette requête pour les numéros :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Contact.objects.filter(phone1__icontains=saisie)
    Et récupérer un queryset avec les numéros me posant problème, genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Contact.objects.filter(phone1__regex=r'[^0-9]').values_list('phone1')
    et boucler sur chacun d'eux en Python

Discussions similaires

  1. [AC-2003] Aller à un enregistrement sans filtrer sur la requête
    Par caesar23 dans le forum IHM
    Réponses: 2
    Dernier message: 02/06/2010, 10h30
  2. [AC-2003] Requête UPDATE sur une table sans relation
    Par SIGER_971 dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 09/07/2009, 09h02
  3. Requête sur date sans tenir compte de l'année
    Par BMATH dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 30/03/2009, 21h23

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