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 :

[VB.NET] : Extraire un chiffre dans une chaine de caractère


Sujet :

VB.NET

  1. #1
    Membre actif Avatar de tssi555
    Analyse système
    Inscrit en
    Juillet 2008
    Messages
    594
    Détails du profil
    Informations professionnelles :
    Activité : Analyse système

    Informations forums :
    Inscription : Juillet 2008
    Messages : 594
    Points : 295
    Points
    295
    Par défaut [VB.NET] : Extraire un chiffre dans une chaine de caractère
    Bonjour,

    J'ai des chaines de caractères comme :

    12 - Intervention Commercial


    Je cherche à extraire le numéro 12 de la chaine.
    En visual FoxPro, ya une fonction qui extrait le numéro et qd elle rencontre l'espace qui suit elle s'arrete enfin donne que le numéro.


    Avez-vous une idée comment pourrais-je faire pareil en VB.NET ?


    Merci d'avance

  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 749
    Points
    39 749
    Par défaut
    expression régulière

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim r As New Regex("(?<num>[0-9]+) - (?<lib>.*)")
    Dim m As Match = r.Match("12 - Intervention Commercial")
    If m.Success Then
        numéro = m.Groups("num")
        libellé = m.Groups("lib")
    End If

  3. #3
    Membre actif Avatar de tssi555
    Analyse système
    Inscrit en
    Juillet 2008
    Messages
    594
    Détails du profil
    Informations professionnelles :
    Activité : Analyse système

    Informations forums :
    Inscription : Juillet 2008
    Messages : 594
    Points : 295
    Points
    295
    Par défaut
    Merci pour ta réponse tomlev.

    Numéro et Libellé je dois les déclarer ou pas ? (parceque Vb les soulignes en bleu)

    Et sans les délcarer je fais :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Msgbox(m.Groups("num"))

    J'ai l'erreur :

    L'argument 'Prompt' ne peut pas être converti en type 'String'.

  4. #4
    Membre actif Avatar de tssi555
    Analyse système
    Inscrit en
    Juillet 2008
    Messages
    594
    Détails du profil
    Informations professionnelles :
    Activité : Analyse système

    Informations forums :
    Inscription : Juillet 2008
    Messages : 594
    Points : 295
    Points
    295
    Par défaut
    Ca fonctionne mnt,

    J'ai ajouté .ToString

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Msgbox(m.Groups("num").ToString)

    Comme ca j'ai le numéro, mais j'ai jemerai bien une petite explication mm si ca fonctionne

    Merci

  5. #5
    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 749
    Points
    39 749
    Par défaut
    Citation Envoyé par tssi555 Voir le message
    Numéro et Libellé je dois les déclarer ou pas ? (parceque Vb les soulignes en bleu)
    Oui, comme n'importe quelle variable...

    Citation Envoyé par tssi555 Voir le message
    J'ai l'erreur :

    L'argument 'Prompt' ne peut pas être converti en type 'String'.
    Erreur de ma part, il faut faire m.Groups("num").Value

    Citation Envoyé par tssi555 Voir le message
    Comme ca j'ai le numéro, mais j'ai jemerai bien une petite explication mm si ca fonctionne
    La méthode Regex.Match évalue une expression régulière par rapport à une chaine passée en paramètre. Ca renvoie le résultat de l'évaluation sous forme d'un objet Match. Match.Success indique si la chaine est conforme à l'expression régulière. Match.Groups contient des sous-chaines capturées par l'expression régulière (spécifiées dans le pattern par "(?<nom> ... )")

  6. #6
    Membre actif Avatar de tssi555
    Analyse système
    Inscrit en
    Juillet 2008
    Messages
    594
    Détails du profil
    Informations professionnelles :
    Activité : Analyse système

    Informations forums :
    Inscription : Juillet 2008
    Messages : 594
    Points : 295
    Points
    295
    Par défaut
    Merci bien tomlev.


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

Discussions similaires

  1. [Débutant] Récuperer chiffres dans une chaine de caractères
    Par Olimpe dans le forum MATLAB
    Réponses: 14
    Dernier message: 16/11/2013, 21h02
  2. Extraire des nombres dans une chaine de caractère
    Par fxfxfx dans le forum Macros et VBA Excel
    Réponses: 14
    Dernier message: 27/05/2013, 10h41
  3. [AC-2007] Extraire plusieurs valeurs dans une chaine de caractères
    Par benny67 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 08/10/2011, 20h09
  4. [CR XI] extraire un nombre dans une chaine de caractère
    Par kikidrome dans le forum Formules
    Réponses: 4
    Dernier message: 01/10/2009, 13h39
  5. Extraire des champs dans une chaine de caractère
    Par clemuche dans le forum Requêtes
    Réponses: 1
    Dernier message: 25/02/2009, 23h24

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