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

Macros et VBA Excel Discussion :

Limiter textbox numérique avec décimal sans lettre


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Novembre 2009
    Messages
    322
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2009
    Messages : 322
    Points : 172
    Points
    172
    Par défaut Limiter textbox numérique avec décimal sans lettre
    Bonjour à tous.

    Je bloque et cherche depuis quelque temps et j'ai besoin de votre aide.

    Mon but, dans un textbox je ne veux pas que l'utilisateur puisse inscrire de texte et que la valeur inscrite soit 4 ou moins.

    Voici mon code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Private Sub textBox1_Change()
        On Error Resume Next
     
    If Not IsNumeric(Right(textbox1, 1)) Then
          MsgBox "Le caractere saisi n'est pas valide. Il sera remplacé par 0 !"
          textbox1 = 0
    End If
     
    End Sub
    Puis

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub TextBox1_Exit(ByVal Cancel As MSForms.ReturnBoolean)
     
    If textbox1.Value > 4 Then
        If textbox1.Value = "" Then Exit Sub
    MsgBox "La valeur doit être inférieure ou égale à 4 !", vbOKOnly, "Votre note !"
    textbox1.Value = ""
     
    Exit Sub
    End If
    End Sub
    Cela fonctionne mais si j'ai un nombre décimal, le code qui limite l'inscription du texte me bloque.

    Quelqu'un a une piste de solution.

    Merci à l'avance


    DLIGHT

  2. #2
    Expert éminent sénior
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

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

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Points : 18 674
    Points
    18 674
    Par défaut

    Bonjour, bonjour,

    si Excel est en version française, le séparateur décimal reconnu par IsNumeric est alors la virgule et non le point !
    (Cela dépend en fait aussi des paramètres régionaux de Windows …)

    Sinon consulter l'exemple du chapitre du contrôle TextBox dans le tutoriel Utiliser les contrôles dans un UserForm

  3. #3
    Membre actif
    Homme Profil pro
    Pompier de service
    Inscrit en
    Février 2014
    Messages
    146
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 58
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Pompier de service

    Informations forums :
    Inscription : Février 2014
    Messages : 146
    Points : 224
    Points
    224
    Par défaut
    Salut,

    Pourquoi pas intercepter la frappe du caractère ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub TextBox1_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
     
    Select Case KeyAscii
     
        Case Is < 48, Is > 57   ' si inférieur à 0 ou supérieur à 9
            KeyAscii = 48       ' on le remplace par 0
        Case Else               ' Autrement, c'est un chiffre
     
    End Select
     
     
    End Sub

Discussions similaires

  1. Conversion numérique vers numérique avec décimal
    Par Shiva dans le forum Requêtes
    Réponses: 5
    Dernier message: 11/06/2015, 15h16
  2. Réponses: 2
    Dernier message: 29/04/2014, 18h12
  3. [XL-2010] Textbox numérique avec virgules
    Par CristofMartins dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 07/05/2013, 10h34
  4. Import de valeur numérique avec décimale
    Par baime dans le forum SAS Base
    Réponses: 1
    Dernier message: 17/08/2012, 22h12
  5. Réponses: 3
    Dernier message: 05/09/2007, 15h00

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