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 :

Rapatrier les données de checkbox


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 106
    Par défaut Rapatrier les données de checkbox
    Bonjour,

    Je bloque sur une macro.
    Je veux que lorsque l'on met son nom et prénom (dans textbox)
    + sélection de case à cocher.
    toutes les valeurs se mettent dans les colonnes correspondantes de la feuille 1
    Si plusieurs cases sont cocher alors cela fera autant de ligne que de case cochées
    Exemple : je met Nom : Boulanger Prénom Laurent
    cases cochées : Rouge et mauve

    Je dois donc trouver en :
    A2 : Boulanger
    B2 : Laurent
    C2 : Rouge (section 1)

    A3 : Boulanger
    B3 : Laurent
    D3 : mauve (section 2)

    ps : voir fichier joint
    Merci pour votre aide
    Fichiers attachés Fichiers attachés

  2. #2
    Membre Expert Avatar de rvtoulon
    Homme Profil pro
    Agent Technique
    Inscrit en
    Mars 2009
    Messages
    1 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Agent Technique
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 042
    Par défaut
    Bonjour,
    il faut que tu boucle sur les controls de tes frames et si elles sont sélectionnées tu copie les données dans ton tableau.
    le code du bouton de commande de ton userform :
    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
    Private Sub CommandButton1_Click()
     
    For Each ctrl In Me.Frame1.Controls
        If TypeOf ctrl Is MSForms.CheckBox Then
          If ctrl.Value = True Then
          Sheets("Feuil1").Range("A65536").End(xlUp).Offset(1, 0) = TextBox1.Value
          Sheets("Feuil1").Range("B65536").End(xlUp).Offset(1, 0) = TextBox2.Value
          Sheets("Feuil1").Range("B65536").End(xlUp).Offset(0, 1) = ctrl.Caption
          End If
        End If
    Next ctrl
     
    For Each ctrl In Me.Frame2.Controls
        If TypeOf ctrl Is MSForms.CheckBox Then
          If ctrl.Value = True Then
          Sheets("Feuil1").Range("A65536").End(xlUp).Offset(1, 0) = TextBox1.Value
          Sheets("Feuil1").Range("B65536").End(xlUp).Offset(1, 0) = TextBox2.Value
          Sheets("Feuil1").Range("B65536").End(xlUp).Offset(0, 2) = ctrl.Caption
          End If
        End If
    Next ctrl
     
    End Sub
    une première boucle sur frame1 et une deuxième boucle sur frame2.
    Tiens nous au courant.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    106
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 106
    Par défaut
    Bonjour,
    Merci pour votre réponse, effectivement j'avais pas pensé à cette solution

    Ca à l'air de bien fonctionné
    Merci pour tout

    il me reste plus qu'à finir mon code pour autoriser un maximum de case à coché

    Par exemple :
    Nombre total de case à cocher = 2

    Avez-vous une piste ?
    Je pensais faire une boucle sur les controls du USF
    Si Ceux nommé checkbox = true >2
    alors checkbox = enable
    Qu'en pensez vous?

Discussions similaires

  1. [XL-2007] rapatrier les données de plusieurs onglets dans un onglet
    Par fthem dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 31/01/2014, 10h18
  2. Réponses: 2
    Dernier message: 16/08/2010, 18h58
  3. Réponses: 4
    Dernier message: 25/05/2010, 14h59
  4. Réponses: 15
    Dernier message: 20/06/2006, 10h29

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