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 :

Explication de code pour remplir des Label [XL-2016]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de Vba14
    Homme Profil pro
    Retraité
    Inscrit en
    Janvier 2019
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2019
    Messages : 440
    Par défaut Explication de code pour remplir des Label
    Bonjour à tous,

    J'ai trouvé ce code qui devrait me permettre d'alimenter des Label en fonction d'un choix fait dans une ComboBox, sauf que je ne comprends pas tout le code.

    Pourriez-vous m'apporter votre lumière s'il vous plait ?
    Je vous en remercie par avance

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Private Sub ComboBox1_Change()
    Dim C As Range, i As Byte
    Set C = ActiveSheet.Cells.Find(What:=ComboBox1) 'Là je ne comprends pas 
    If Not C Is Nothing Then
        For i = 4 To 6 'Là non plus
            Me.Controls("Label" & i).Caption = C.Offset(0, i - 3).Value 'Là non plus
        Next i
    End If
    End Sub

  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
    bonjour
    ce n'est qu'une explication d'un débutant et autodidacte donc un risque d'erreur à ne pas négliger
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Private Sub ComboBox1_Change() ' événement se déclenche suite au changement de la valeur de la combobox
    Dim C As Range, i As Byte
    Set C = ActiveSheet.Cells.Find(What:=ComboBox1) ' chercher dans la feuille active la valeur de la combobox 
    If Not C Is Nothing Then  'si la valeur de la combobx existe dans l'une des cellule de la feuille active alors
        For i = 4 To 6 ' puisque tes label  nommé label 4 , label 5 , label 6 donc i va de 4 à 6
            Me.Controls("Label" & i).Caption = C.Offset(0, i - 3).Value ' attribuer les résultats de recherche ci haut effectué : Me.Controls("Label" & i).Caption = label 4 = la cellule trouvée et i-3 parce que le nom de tes label commence par 4 donc pour revenir au premier résultat on tranche 3 et ainsi de suite
        Next i ' remplir la deuxieme label c'est à dire label 5 et puis label 6
    End If 'fin de condition
    End Sub
    BONNE CONTINUATION

  3. #3
    Membre éclairé Avatar de Vba14
    Homme Profil pro
    Retraité
    Inscrit en
    Janvier 2019
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2019
    Messages : 440
    Par défaut
    Bonjour BENNASR et merci pour ta réponse.

    Je comprends mieux à présent et je vais pouvoir avancer.

    Très cordialement

    Vba14

  4. #4
    Membre éclairé Avatar de Vba14
    Homme Profil pro
    Retraité
    Inscrit en
    Janvier 2019
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2019
    Messages : 440
    Par défaut
    Je reviens sur cette discussion car je souhaiterai avoir une explication supplémentaire :

    For i = 4 To 6 ' puisque tes label nommé label 4 , label 5 , label 6 donc i va de 4 à 6
    sauf que dans mon cas, tout mes Label sont nommés (Label_Person, Label_Prépa, etc...) et il y en a 10.

    Est-ce que je peux passer par le n° Index et si oui comment ?

    Merci par avance pour vos réponses

  5. #5
    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
    normalement le i est le numéro d'index et non pas la caption

  6. #6
    Membre éclairé Avatar de Vba14
    Homme Profil pro
    Retraité
    Inscrit en
    Janvier 2019
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Janvier 2019
    Messages : 440
    Par défaut
    Ah ok, je n'avais pas compris.
    Merci

    Par contre est-ce qu'il faut que les N° d'Index suivent l'ordre de classement de mes colonnes dans mon tableau. Par exemple l'Index1 doit correspondre à la colonne A, l'Index2 colonne B, etc...

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

Discussions similaires

  1. [AC-2013] Code pour modifier le label des boutons d'une boite de dialogue
    Par rag83 dans le forum VBA Access
    Réponses: 3
    Dernier message: 08/12/2015, 21h49
  2. [XL-2007] Code pour remplir des cellules non basé sur les colonnes
    Par Philippe_shelby dans le forum Macros et VBA Excel
    Réponses: 16
    Dernier message: 22/01/2015, 23h46
  3. recherche code pour inserer des champs a remplir dans un pdf
    Par JRTConcept dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 09/06/2014, 11h42
  4. Réponses: 1
    Dernier message: 11/10/2006, 14h24
  5. Réponses: 5
    Dernier message: 14/05/2006, 12h57

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