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 :

format date dans un textbox


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 83
    Points : 34
    Points
    34
    Par défaut format date dans un textbox
    bonjour à tous, je cherche à obliger un format date dans un textbox, de type jj/mm/aaaa,
    j'ai donc vu la doc sur le site, mais cela ne marche pas et je ne vois pas pourquoi:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    Private Sub TextBox1_Change()
    	Dim Valeur As Byte
    	TextBox1.MaxLength = 10 'nb caractères maxi autorisé dans le textbox
    	Valeur = Len(TextBox1)
    	If Valeur = 2 Or Valeur = 5 Then TextBox1 = TextBox1 & "/"
    End Sub
    
    
    'Ensuite pour vérifier que c'est bien une date qui a été saisie
    Private Sub CommandButton1_Click()
        If Not IsDate(TextBox1) Then
            MsgBox "Format incorrect"
            TextBox1 = ""
            Exit Sub
            Else
            MsgBox "Format correct"
            '...la suite de la procédure
        End If
    End Sub
    c'est la partie en gras qui doit comporter une erreur,
    alors si qq'un a une idée

  2. #2
    Membre à l'essai
    Inscrit en
    Juin 2008
    Messages
    20
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 20
    Points : 12
    Points
    12
    Par défaut
    bonjour,

    dans l'aide j'ai trouvé ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    MyStr = Format(5, "0.00%")    ' Renvoie "500,00%"
    à voir pour une adaptation...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    mystrg= format (textbox1, "/")
    sinon peut être ça ( vu en faisant un enregistrement de macro):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Selection.NumberFormat = "dd/mm/yy;@"
    mais veut tu que le format dd/mm/aaaa soit visible dans ta textbox ou dans la cellule dans laquelle elle va être inscrite?
    parce que sinon tu peux forcer la cellule et pis voilà... pour ça vois avec le dernier bout de code

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 83
    Points : 34
    Points
    34
    Par défaut
    oui ça doit apparaitre dans la cellule, donc je dois définir la cellule comme étant une date, mais le problème c'est qu'il n'y a pas le format jj/mm/aaaa (il y a par contre jj/mm/aa ...)

    donc je ne vois pas comment faire

  4. #4
    Expert éminent
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Bonjour tlm,

    J'ai essayé ton code ci-dessous
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub TextBox1_Change()
    Dim Valeur As Byte
    Valeur = Len(TextBox1)
    If Valeur = 2 Or Valeur = 5 Then TextBox1 = TextBox1 & "/"
    End Sub
    il fonctionne sans problème.

    Cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TextBox1.MaxLength = 10 'nb caractères maxi autorisé dans le textbox
    n'est pas nécessaire dans ton code, tu peux fixer la longueur max directement dans les propriétés de ta TextBox

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    83
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 83
    Points : 34
    Points
    34
    Par défaut
    effectivement j'ai réessayé et ça marche, donc merci ça marche nickel
    par contre pour le commandbutton1, je ne vois pas bien à quoi ça sert donc je l'ai enlevé

    et maxlength est paramétrable, donc pas besoin de formule

    merci

  6. #6
    Membre éclairé

    Profil pro
    Inscrit en
    Mai 2007
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 514
    Points : 824
    Points
    824
    Par défaut
    Bonjour,

    Jette un oeil ici

    Cordialement,

    Tirex28/

Discussions similaires

  1. [XL-2007] COMMENT APPLIQUER un format DATE dans un TextBox
    Par NICOLE 0075 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 21/09/2013, 16h03
  2. [XL-2002] Format date dans un textbox
    Par thomasdu40 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 12/10/2010, 11h25
  3. Format date dans un TextBox en Vba
    Par NEC14 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 05/12/2008, 08h44
  4. Réponses: 1
    Dernier message: 10/08/2008, 12h52

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