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 :

Afficher le Label de CheckBox Cochées dans une TextBox [XL-2016]


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2018
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2018
    Messages : 13
    Points : 8
    Points
    8
    Par défaut Afficher le Label de CheckBox Cochées dans une TextBox
    Bonjour,

    Je vais aller droit au but.

    J'ai un UserForm à 2 pages. Sur le premier il y a plusieurs ComboBox qui me servent à localiser une cellule à modifier selon la valeur d'entrée de la ligne et de la colonne.

    Mais il y a également une TextBox.

    Sur la deuxième page il y a 32 Checkboxs.

    L'objectif : Afficher le label des checkboxs cochées, dans la textbox.

    Mon problème : Mon code me renvoit bien le nom des checkboxs dans ma textbox. Mais ils ne correspondent pas à ceux de checkbox cochées.

    Ex : je coche la 1,2,11,15. Mon code me renvoit le bon nombre de checkbox mais le nom de la 1,2,3,4.

    Mon Code :

    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
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
     Option Explicit
    Dim ln, col
    Private Sub CommandButton_accepter_Click()
    Cells(ln, col) = TextBox_Intit.Value
    End Sub
    Private Sub CommandButton_annuler_Click()
    Unload Me
    UserForm4.Show
    End Sub
    Private Sub CommandButton_quitter_Click()
    Unload Me
    End Sub
    Private Sub CommandButton2_Click()
    Dim Ctrl As Control
    Dim j As Integer
    j = 1
    For Each Ctrl In UserForm4.Controls
        If TypeName(Ctrl) = "CheckBox" Then
            If Ctrl.Value = True Then
            TextBox_Intit.Value = TextBox_Intit.Value & Me.Controls("CheckBox" & Active.CheckBox.Name).Caption & "  "
            j = j + 1
            End If
        End If
    Next Ctrl
    Me.MultiPage1.Value = Me.MultiPage1.Value - 1
    End Sub
    Private Sub MultiPage1_Change()
    End Sub
     
    Private Sub UserForm_Initialize()
    ComboBox_prepa.List = Application.Transpose(Range("C1:E1"))
    ComboBox_version.List = Range("A2:A43").Value
    End Sub
    Private Sub ComboBox_prepa_Change()
        Call Saisies
    End Sub
    Private Sub ComboBox_version_Change()
        Call Saisies
    End Sub
    Sub Saisies()
        If ComboBox_prepa.ListIndex > -1 And ComboBox_version.ListIndex > -1 Then
            ln = 2 + ComboBox_version.ListIndex
            col = 3 + ComboBox_prepa.ListIndex
            TextBox_Cell = "Ln : " & ln & " , " & "Col : " & col
        End If
    End Sub
    Merci pour votre aide,
    Cdlt

  2. #2
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2018
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2018
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    J'apporte une correction à l'énoncé après avoir relevé une erreur dans mon code.
    Voici la correction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
            TextBox_Intit.Value = TextBox_Intit.Value & Me.Controls("CheckBox" & j).Caption & "  "

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Juillet 2018
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Juillet 2018
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    La Solution

    Je me permets d'apporter la solution, Très Très ... trop, simple.

    Pour ceux que ça intéresse :

    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
    Private Sub CommandButton2_Click()
     
    Dim Ctrl As Control
    Dim j As Integer
    Dim Chk As MSForms.CheckBox
    For Each Ctrl In UserForm4.Controls
     
        If TypeOf Ctrl Is MSForms.CheckBox Then
            Set Chk = Ctrl
            If Chk.Value = True Then
                TextBox_Intit.Value = TextBox_Intit.Value & Chk.Caption & "  "
     
            End If
        End If
    Next Ctrl
    End Sub

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

Discussions similaires

  1. Afficher du/des noms coches dans des Checkboxs dynamique dans une textbox
    Par rampage92 dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 22/12/2016, 11h13
  2. [SP-2007] Récupérer les checkboxes cochées dans une custom task
    Par nostaze dans le forum SharePoint
    Réponses: 0
    Dernier message: 21/05/2012, 16h21
  3. Affichier les CheckBox coché dans une boucle
    Par PrinceMaster77 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 28/05/2010, 15h09
  4. [PHP 5.3] Récupérer les checkbox cochées dans une variable
    Par Invité dans le forum Langage
    Réponses: 6
    Dernier message: 01/06/2009, 12h25
  5. Afficher le nom d'un "dossier" dans une TextBox ?
    Par XpFive dans le forum VB 6 et antérieur
    Réponses: 12
    Dernier message: 05/06/2008, 20h05

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