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 :

Nom bouton de commande selon condition


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 974
    Par défaut Nom bouton de commande selon condition
    Bonjour à tous
    Une feuille nommé "AlF3" en colonne A la date de la vente et en colonne B on extrait le mois avec la formule : "texte (A2; "mmmm_yyyy") , et en colonne D le nom de client.
    Je cherche à créer un userform avec un combobox alimenter sans doublons par la colonne B et si le choix est effectué, les boutons de commande se nomme avec les noms des clients figurants en colonne D
    pour faire ça j'ai initialiser mon userform comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    rivate Sub UserForm_Initialize()
        Dim j As Long
        NbLeg = Sheets("AlF3").Range("A" & Rows.Count).End(xlUp).Row
        For j = 2 To NbLeg
        ComboBox1 = Sheets("AlF3").Range("B" & j)
        If ComboBox1.ListIndex = -1 Then ComboBox1.AddItem Sheets("AlF3").Range("B" & j)
        Next j
    End Sub
    je bloque ici : Pour nommer les boutons de commande :
    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
    Dim plage As Range
    Dim cell As Range
    Dim ob As Object
    Dim CodeRech As String
    Dim i As Integer
    i = 2
    CodeRech = ComboBox1.Value
    With Sheets("AlF3")
    Set plage = .Range("B2:B" & NbLeg)
          For Each ob In UserForm1.Controls
                        If ob.Name = "CommandButton" & i Then
                        For Each cell In plage
                        If cell.Value = CodeRech Then
                        ob.Caption = Sheets("AlF3").Cells(cell.Row, 4) '& "  " & Sheets("AlF3").Cells(cell.Row, 1)
                        End If
                        Next cell
                        End If
                        i = i + 1
           Next ob
    End With
    Merci d'avance

  2. #2
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 974
    Par défaut
    bonsoir à tous
    j'ai arriver à résoudre ce partie de code moyennant du bricolage
    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
    Dim plage As Range
    Dim cell As Range
    Dim CodeRech As String
    Dim i As Integer
    i = 2
    CodeRech = ComboBox1.Value
    With Sheets("AlF3")
    Set plage = .Range("B2:B" & NbLeg)
        For Each cell In plage
          If cell.Value = CodeRech Then
            For Each ob In UserForm1.Controls
                 If ob.Name = "CommandButton" & i Then
                  ob.Caption = Sheets("AlF3").Cells(cell.Row, 4) & "  du  " & Sheets("AlF3").Cells(cell.Row, 1)
                 End If
             Next ob
             i = i + 1
             End If
          Next cell
    End With
    le problème maintenant c'est une fois les bouton sont chargés je cherche à masquer les boutons de commande
    qui sont encore appelé CommandButton et qq chose (un nombre)
    j'ai essayer avec ça mais msg d'erreur propriété ou éthode non gérer par cet objet
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    For Each ob In UserForm1.Controls
                 If ob.Name = "CommandButton" & i And ob.Caption Like "CommandButton" & i Then
                  ob.Visible = False
                 End If
             Next ob
    End Sub
    Merci à tous

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

Discussions similaires

  1. [AC-2010] Bouton de commande avec "condition WHERE" à 2 variables
    Par albayt dans le forum IHM
    Réponses: 2
    Dernier message: 16/11/2013, 16h06
  2. Problème Chgt noms boutons de commande
    Par Chr22 dans le forum VBA Word
    Réponses: 2
    Dernier message: 28/02/2012, 17h10
  3. verrouiller l'accès à un bouton de commande selon l'utilisateur
    Par arkorrigan dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 02/06/2008, 13h33
  4. [VBA][Excel] Nom d'une command bouton
    Par ecirb dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 17/04/2007, 11h29
  5. Bouton de commande avec condition
    Par rogeryzf dans le forum Access
    Réponses: 5
    Dernier message: 22/02/2006, 14h13

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