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 :

Insertion d’une date calendrier dans un TextBox ou cellule


Sujet :

Macros et VBA Excel

  1. #1
    apt
    apt est déconnecté
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    867
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 867
    Points : 118
    Points
    118
    Par défaut Insertion d’une date calendrier dans un TextBox ou cellule
    Bonsoir à tous,

    Dans une application j’ai un calendrier dans un USF sous le nom CalFrm.

    Par un premier bouton j’appelle une macro qui me fait afficher CalFrm pour insertion de la date choisie dans une cellule.

    Par un deuxième bouton, j’appelle un USF qui contient un TextBox1 et TextBox2 pour m’afficher les dates choisies (Date1 et Date2) depuis le même USF CalFrm

    Alors comment écrire un code pour différencier l’insertion de la date choisie depuis l’USF CalFrm dans la cellule pour le premier bouton ou dans le TextBox1, TextBox2 pour le deuxième bouton ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub CommandButton1_Click()  'Bouton OK du calendrier
        If frm = 1 Then
            PersoFrm.ActiveControl.Value = Calfrm.Calendar1.Value
        Else
            'Place the date from the calendar into the cell
            Sheets("BD").[H10].Value = Calfrm.Calendar1.Value
            Unload Me
        End If
        Unload Me
    End Sub
    Merci d’avance.

  2. #2
    Membre émérite
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 816
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 816
    Points : 2 954
    Points
    2 954
    Billets dans le blog
    10
    Par défaut
    Bonjour,
    Deux boutons = deux actions = deux codes...

    J'avoue ne pas avoir tout saisi à la problématique...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub CommandButton1_Click()  'Bouton OK du calendrier
        If frm = 1 Then
            PersoFrm.ActiveControl.Value = Calfrm.Calendar1.Value
        Else
            'Place the date from the calendar into the cell
            Sheets("BD").[H10].Value = Calfrm.Calendar1.Value
            Unload Me
        End If
        Unload Me
    End Sub
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub CommandButton2_Click()  
        If frm = 1 Then
            PersoFrm.ActiveControl.Value = Calfrm.Calendar1.Value
        Else
            'Place the date from the calendar into the textbox
            TextBox1.Value = Calfrm.Calendar1.Value
            Unload Me
        End If
        Unload Me
    End Sub
    Après, sans savoir ce que tu veux faire ni à quoi correspondent : frm, PersoFrm, il est difficile de t'en dire davantage...
    Cordialement,
    Franck

  3. #3
    apt
    apt est déconnecté
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    867
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 867
    Points : 118
    Points
    118
    Par défaut
    Bonjour pijaku,

    Merci de m'avoir répondu.

    En PJ un exemple.

    Fichiers attachés Fichiers attachés

  4. #4
    apt
    apt est déconnecté
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    867
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 867
    Points : 118
    Points
    118
    Par défaut
    Bonsoir,

    Une solution m'a été proposée !

    On récupère toujours la date sélectionnée du calendrier, après on l'insère selon le bouton qui a fait appel au calendrier :

    Si c'était le bouton 1 (écriture dans la feuille) le code sera :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Sub Journalier()
        CalFrm.Show
        Sheets("BD").[H10].Value = CalFrm.Calendar1.Value
        Unload CalFrm
    End Sub
    Si c'était depuis un TextBox on écrira :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Private Sub TextBox1_MouseUp(ByVal Button As Integer, ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single)
        CalFrm.Show
        TextBox1.Value = CalFrm.Calendar1.Value
        Unload CalFrm
    End Sub
     
    Private Sub TextBox2_MouseUp(ByVal Button As Integer, ByVal Shift As Integer, ByVal X As Single, ByVal Y As Single)
        CalFrm.Show
        TextBox2.Value = CalFrm.Calendar1.Value
        Unload CalFrm
    End Sub
    Seulement il reste, comment définir le control actif avant l'appel du calendrier:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Dim Nom As String 
    Nom = PersoFrm.Controls("Frame1").ActiveControl.Name 
    PersoFrm.Controls(Nom).Value = CalFrm.Calendar1.Value
    parce que cette ligne déclenche une erreur :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Nom = PersoFrm.Controls("Frame1").ActiveControl.Name
    Erreur d'exécution '91':
    Variable objet ou variable de bloc With non définie
    Merci d'avance.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Décembre 2010
    Messages
    99
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2010
    Messages : 99
    Points : 141
    Points
    141
    Par défaut
    Bonjour Apt le forum
    tu aimes bien te compliquer la vie, ton fichier en retour, avec les modifs, par contre j'aimerais bien connaître l'utilité du bouton valider dans l'userform perso??
    a+
    papou
    Fichiers attachés Fichiers attachés

  6. #6
    Expert éminent Avatar de jfontaine
    Homme Profil pro
    Contrôleur de Gestion
    Inscrit en
    Juin 2006
    Messages
    4 754
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Contrôleur de Gestion

    Informations forums :
    Inscription : Juin 2006
    Messages : 4 754
    Points : 9 396
    Points
    9 396
    Par défaut
    Bonjour,

    Si le but est d'aider l'utilisateur à la saisie d'une date dans une cellule, regardes cette contribution
    http://www.developpez.net/forums/d44...de-calendrier/
    Jérôme

  7. #7
    apt
    apt est déconnecté
    Membre régulier
    Inscrit en
    Mai 2002
    Messages
    867
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 867
    Points : 118
    Points
    118
    Par défaut
    Bonjour Papou, jFontaine,

    Merci Papou pour le code et jFontaine pour le lien.

    Citation Envoyé par Paritec Voir le message
    par contre j'aimerais bien connaître l'utilité du bouton valider dans l'userform perso??
    Il sert à lancer le filtre élaboré avec les critères renseignés dans l'USF.

    Dans ce fil :

    http://www.developpez.net/forums/d12...ore-laide-usf/

    l'exemple fourni montre l'utilité du bouton "Valider"

Discussions similaires

  1. [XL-2007] Insertion date calendrier dans unTextBox
    Par eliot.raymond dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 19/10/2013, 11h55
  2. insertion d'un calendrier dans formulaire Acrobat
    Par gnimitz dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 14/10/2013, 15h32
  3. [MCD] entité date/calendrier dans MCD
    Par le beauceron dans le forum Schéma
    Réponses: 4
    Dernier message: 11/02/2012, 09h37
  4. [E-03] Intégrer un format date spécifique dans une textBox
    Par moilou2 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 01/12/2008, 14h36
  5. [Dates] Calendrier dans une liste déroulante
    Par azeggouar dans le forum Langage
    Réponses: 2
    Dernier message: 20/07/2007, 02h35

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