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

VB.NET Discussion :

Vérification d'un Numéro


Sujet :

VB.NET

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    33
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 33
    Points : 31
    Points
    31
    Par défaut Vérification d'un Numéro
    Bonjour,
    EN vb .net, je veux avoir un regex qui me permet de controler un Num d'inscription.

    Le num doit comporter jour, mois de naissance et numero d'inscription examlpe: 15020001

    Cette procédure ne me permet de le faire. est ce que vous pouvez vérifier l'origine d'erreur?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Txt_insc_LostFocus(ByVal sender As Object, ByVal e As System.EventArgs) Handles Txt_insc.LostFocus
            Dim reg As Regex = New Regex("^[0-2]{1}[0-9]{1}[1-12]{1}[0-9]{4}$")
            If reg.IsMatch(Txt_insc.Text) Then
                Exit Sub
            Else
                MsgBox("Le numéro d'inscription doit comporter jour, mois de naissance et numero d'inscription examlpe: 15020001", MsgBoxStyle.Critical)
            End If
        End Sub

  2. #2
    Rédacteur/Modérateur


    Homme Profil pro
    Développeur .NET
    Inscrit en
    Février 2004
    Messages
    19 875
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Paris (Île de France)

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

    Informations forums :
    Inscription : Février 2004
    Messages : 19 875
    Points : 39 754
    Points
    39 754
    Par défaut
    Ta regex est fausse : par exemple, on ne peut pas saisir 3107001, puisque le premier chiffre ne peut pas être 3... D'autre part, "[1-12]" n'est pas un ensemble de caractères correct : 12 n'est pas 1 caractère mais 2 caractères... en fait ce que tu as écrit signifie "tous les caractères de 1 à 1, ainsi que le caractère 2"

    Bref... de toutes façons, une regex pour faire ça ne me semble pas très appropriée, parce que tu ne peux pas vérifier, par exemple, que le jour existe dans le mois (par exemple, 30020001 n'est pas possible). A la rigueur, tu peux t'en servir pour vérifier qu'il n'y a que des chiffres ("\d{8}"), mais c'est tout...
    Il vaudrait mieux analyser la chaine manuellement pour le reste (en utilisant éventuellement DateTime.TryParse)

  3. #3
    Expert éminent
    Avatar de smyley
    Profil pro
    Inscrit en
    Juin 2003
    Messages
    6 270
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 6 270
    Points : 8 344
    Points
    8 344
    Par défaut
    Je dirais qu'il suffit de couper avec String.Split ou String.Substring vu que la chaine à toujours la même longueur, cf 15020001 deviens 15 02 0001 et après un int.Parse pour gérer chaque nombre 1 par 1.
    Il restera juste à vérifier que la date de naissance est valide mais tu aura des problèmes pour le mois de février justement

Discussions similaires

  1. [RegEx] Vérification de numéro de sécurité sociale
    Par Crunkman dans le forum Langage
    Réponses: 19
    Dernier message: 26/02/2016, 15h11
  2. Réponses: 5
    Dernier message: 25/10/2013, 11h51
  3. Vérification numéro de téléphone dans un formulaire
    Par riderfun dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 01/07/2008, 14h56
  4. Vérification numéro RCS
    Par Louka-65 dans le forum Langage
    Réponses: 1
    Dernier message: 03/06/2008, 18h01
  5. Réponses: 2
    Dernier message: 03/03/2008, 03h31

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