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 :

Imposer un format de date


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    491
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 491
    Par défaut Imposer un format de date
    Bonjour (ou re),

    Sur tous mes onglets (Lundi au Vendredi), je demande à l'utilisateur de renseigner une date.

    Je voudrais qu'un message apparaisse si le format de la date n'est pas le suivant : jj/mm/aaaa

    J'ai trouvé un truc comme ça mais je ne sais pas comment l'adapter :
    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
    Dim Valeur As Byte
     
        Range("G5").Value = Date_visite
        Date_visite.MaxLength = 10 'nb caractères maxi autorisé
     
        Valeur = Len(Date_visite)
        If Valeur = 2 Or Valeur = 5 Then Date_visite = Date_visite & "/"
     
            If Not IsDate(Date_visite) Then
            MsgBox "Format incorrect"
            Date_visite = ""
            Exit Sub
            Else
            MsgBox "Format correct"
            End If
    Le pb c'est que je ne sais pas où placé le code et surtout comment faire pour que la macro se lancer lorsque la cellule est renseigné.

    Par avance merci de votre éclairage.

    Nini

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    2 130
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 2 130
    Par défaut
    Salut liop49 et le forum
    pas tout à fait d'accord avec toi, sur le principe. Donc une autre poposition.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Private Sub Workbook_SheetChange(ByVal Sh As Object, ByVal Target As Range)
    If Target.Address(0, 0) <> "G5" Or IsEmpty([G5]) Then Exit Sub
    'si l'adresse des cellules modifiées est différente de G5 ou
    'que G5 est vide alors sortir
    If Not IsDate([G5]) Then
    'si G5 ne correspond pas à une date
        MsgBox "G5 doit être une date !" & Chr(13) & "Veuillez ressarsir une Date"
        [G5].ClearContents
        'effacer G5
    End If
    [G5].NumberFormat = "dd/mm/yy"
    End Sub
    comme tu fais des macros, tu connais un minimum.

    Sous VBEditor, tu colles cette macro dans le module ThisWorkBook (il est dans la fenêtre en haut à gauche VBA-Poject)

    Si tu utilises d'autres feuilles dans ton classeur, il faut exclure des feuilles dont G5 peut ne pas être une date (if sh.name = "..." or sh.name = "..." then exit sub) ou limiter aux feuilles concernées (if sh.name<>"lundi"...)
    : celui qui demande le moins de fatigue
    A+

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

Discussions similaires

  1. [XL-2003] imposer le format date fr
    Par Thierry2B dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 04/02/2011, 11h14
  2. debutant:imposer un format sur la date
    Par kam81 dans le forum Jasper
    Réponses: 1
    Dernier message: 30/11/2008, 18h10
  3. Comment imposer le format des dates ?
    Par Arfigado dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 05/09/2006, 18h51
  4. [ADO.Net][C#] Comment imposer le format de date ?
    Par WELCOMSMAIL dans le forum Accès aux données
    Réponses: 3
    Dernier message: 03/05/2006, 20h21
  5. comment imposer un format de date dans DB2?
    Par Mittou dans le forum Langage SQL
    Réponses: 2
    Dernier message: 18/10/2005, 08h16

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