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 :

Si cellule = x alors Label est visible


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de anarchiste-mouton
    Homme Profil pro
    ceci
    Inscrit en
    Décembre 2017
    Messages
    69
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : ceci
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2017
    Messages : 69
    Par défaut Si cellule = x alors Label est visible
    Bonjour,

    J'ai un formulaire qui contient 10 labels nommés de "Label100" à "Label109"

    J'aimerais les rendre visible en fonction de la valeur d'une cellule qui leur est propre.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    Dim maCell As Range, i As Byte, monLabel As Object
     
     i = 0
     
     For Each maCell In Worksheets("Feuil2").Range("G2:G11")
            monLabel = "Label10" & i
            If maCell.Value = "todo" Then monLabel.Visible = True
            i = i + 1
     Next
    Je comprends que ça cloche à la ligne 7 mais je ne sais pas quelle syntaxe utiliser pour corriger ça, auriez-vous une piste?

  2. #2
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    Salut,

    Pour désigner un contrôle, tu peux concaténer le nom en utilisant la méthode "Controls"
    Pour utiliser 2 valeurs booléennes, il n'est pas nécessaires d'employer la méthode "If"

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Worksheets("lafeuille").Visible = (Worksheets("Données").[A5] = 1)
    Tu peux adapter cette méthode à tes contrôles.

    Sur les formulaires, 2tutoriels de référence
    Les Userforms
    Les contrôles dans les Userforms/

  3. #3
    Membre confirmé Avatar de anarchiste-mouton
    Homme Profil pro
    ceci
    Inscrit en
    Décembre 2017
    Messages
    69
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : ceci
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2017
    Messages : 69
    Par défaut
    Merci MarcelG,

    je prends note de ton raccourci pour éviter le if, donc voici ce que j'obtiens avec la propriété .Controls()

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Dim maCell As Range, i As Byte
        i = 0
        For Each maCell In Worksheets("Feuil2").Range("G2:G11")
            'If maCell.Value = "todo" Then Me.Controls("Label10" & i).Visible = True         = à la ligne du dessous
            Me.Controls("Label10" & i).Visible = (maCell = "todo")
            i = i + 1
        Next
    Bonne fin de journée et encore merci !

  4. #4
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par anarchiste-mouton Voir le message
    Bonjour,

    A tester :
    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
     
    Sub Test()
     
    Dim ShLabel As Worksheet
    Dim AireLabels As Range
    Dim I As Byte, J As Integer
     
        Set ShLabel = Sheets("Feuil2")
     
        With ShLabel
             For J = 1 To 10
                 For I = 1 To .Shapes.Count
                     If .Shapes(I).Name = "Label1" & J Then .Shapes(I).Visible = False
                 Next I
              Next J
     
              Set AireLabels = .Range("G2:G11")
              With AireLabels
                     For I = 1 To .Count
                         If AireLabels(I) = "todo" Then
                            ShLabel.Shapes("Label1" & I).Visible = True
                         End If
                     Next I
              End With
     
        End With
     
        Set AireLabels = Nothing
        Set ShLabel = Nothing
     
    End Sub

  5. #5
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    Salut Eric,

    Ravi de te retrouver (je dois d'ailleurs te revenir pour une discussion que j'ai ouverte. Don't Act)

    Que penses tu de

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ShLabel.Shapes("Label1" & I).Visible = (AireLabels(I) = "todo")

  6. #6
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par MarcelG Voir le message
    Bonjour Marcel,

    Comme tu as pu le deviner, mon code concerne des contrôles ActiveX directement implantés sur la feuille et non dans un userform. Ta ligne de code donne ce message :

    Pièce jointe 424692

    Pour mémoire :
    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
     
    Sub Test()
     
    Dim ShLabel As Worksheet
    Dim AireLabels As Range
    Dim I As Byte, J As Integer
     
        Set ShLabel = Sheets("Feuil2")
     
        With ShLabel
             For J = 1 To 10
                 For I = 1 To .Shapes.Count
                     If .Shapes(I).Name = "Label1" & J Then .Shapes(I).Visible = False
                 Next I
              Next J
     
              Set AireLabels = .Range("G2:G11")
              With AireLabels
                     For I = 1 To .Count
                         Debug.Print AireLabels(I) = "todo"
                         ShLabel.Shapes("Label1" & I).Visible = (AireLabels(I) = "todo")
                        '  If AireLabels(I) = "todo" Then
                        '     ShLabel.Shapes("Label1" & I).Visible = True
                        '  End If
                     Next I
              End With
     
        End With
     
        Set AireLabels = Nothing
        Set ShLabel = Nothing
     
    End Sub

  7. #7
    Expert confirmé
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Billets dans le blog
    7
    Par défaut
    Bonjour Eric,

    Au temps pour moi.

    A plus tard.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 05/08/2016, 20h42
  2. Réponses: 5
    Dernier message: 02/05/2013, 20h56
  3. Réponses: 6
    Dernier message: 18/07/2012, 09h08
  4. Réponses: 2
    Dernier message: 11/02/2006, 12h56
  5. Réponses: 14
    Dernier message: 27/06/2005, 19h12

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