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 :

supprimer des labels crées dynamiquement


Sujet :

Macros et VBA Excel

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

    Informations forums :
    Inscription : Février 2007
    Messages : 491
    Points : 542
    Points
    542
    Par défaut supprimer des labels crées dynamiquement
    bonsoir a tous

    ma demande est dans le titre

    j ai crée un userforms avec une listbox , dans cette list je peux choisir plusieurs feuilles.
    en clickant sur une d elles je rempli mes labels crées dynamiquement.
    le code juste pour le fun

    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
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
     
    Option Explicit
    Option Base 1
    Dim fl As Worksheet
     
     
     
     
    Private Sub lbxgrille_Click()
    Call sup_bouton  'ici je veux supprimer les labels
    Set fl = Worksheets(lbxgrille.Value)
    Call affichage
    End Sub
     
     
    Private Sub UserForm_Initialize()
    Dim fl As Worksheet
    For Each fl In Worksheets
        If Left(fl.Name, 9) = "grille du" Then
            lbxgrille.AddItem fl.Name
        End If
    Next
    End Sub
     
     
    Sub affichage()
    Dim nbcol
    Dim nbligne
    Dim lab() As Control
    Dim tabaff()
    Dim i  As Integer
    Dim j As Integer
    nbligne = fl.Cells(65536, 1).End(xlUp).Row
    nbcol = fl.Cells(1, 256).End(xlToLeft).Column
    ReDim tabaff(nbligne, nbcol)
    ReDim lab(nbligne * nbcol)
     
        For i = LBound(tabaff, 1) To UBound(tabaff, 1) 'boucle sur les col
            For j = LBound(tabaff, 2) To UBound(tabaff, 2) 'boucle sur les lignes
                If i = 1 And j > 2 And j < UBound(tabaff, 2) Then  'prenom en 4 lettre
                    tabaff(i, j) = Left(fl.Cells(i, j).Value, 4)
                Else: tabaff(i, j) = fl.Cells(i, j).Value
                End If
     
            Next j
        Next i
    For i = LBound(tabaff, 1) To UBound(tabaff, 1) 'contenu des ligne
            For j = LBound(tabaff, 2) To UBound(tabaff, 2) ' contenu des col
            Set lab(j) = vudesgrilles.Controls.Add("forms.label.1")
                With lab(j)
                    .Height = 12
                If j < 3 Then
                    .Left = 5 + (j - 1) * 70
                    .Width = 70
                Else
                    .Left = 5 + (j - 1) * 30 + 80
                    .Width = 25
                End If
                    .top = 25 + i * 18
                    .Font.Size = 8
                    .Caption = tabaff(i, j)
                    .TextAlign = fmTextAlignLeft
                End With
     
            Next j
        Next i
     
    Set fl = Nothing
    End Sub
    Sub sup_bouton()
    Dim lab As Label
     
    For Each lab In grlabel
    lab.Delete
    Next lab
    End Sub
    nota : je n ai pas besoin de recuperer les evenements de ces labels

    le pb est le suivant :
    je dois supprimer les labels entre chaque appel de feuille
    j ai essayer de boucler sur les controls :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    For Each Ctrl In Controls
        If TypeOf Ctrl Is MSForms.label Then  Ctrl.Object.delete ' la propriété delete  
    Next Ctrl
    la propriété delete existe mais pour le label pas les controls

    j ai essayé de boucler sur les collections label : pb elle n existe pas
    j ai essayé de creer une collection label : idem

    il ne me reste plus qu un module de classe mais juste pour une suppression de
    label !!! cela fait un peu riche


    si vous avez d autre idée

  2. #2
    Membre éclairé

    Profil pro
    Inscrit en
    Mai 2007
    Messages
    514
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 514
    Points : 824
    Points
    824
    Par défaut
    Bonsoir,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Sub sup_bouton()
        Dim lab As Control
        For Each lab In Controls
            If TypeOf lab Is MSForms.Label Then Controls.Remove lab.Name
        Next
    End Sub
    Cordialement,

    Tirex28/

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

    Informations forums :
    Inscription : Février 2007
    Messages : 491
    Points : 542
    Points
    542
    Par défaut
    merci tirex28

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

Discussions similaires

  1. [XL-2003] supprimer des objets crées dynamiquement
    Par neninio31 dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 26/06/2009, 11h28
  2. Action sur des boutons crées dynamiquement
    Par barthelus76 dans le forum SWT/JFace
    Réponses: 13
    Dernier message: 28/06/2007, 20h32
  3. suppression des images créées dynamiquement
    Par bhahmed dans le forum C++Builder
    Réponses: 3
    Dernier message: 10/09/2006, 21h37
  4. déplacement des Timage créées dynamiquement
    Par bhahmed dans le forum C++Builder
    Réponses: 18
    Dernier message: 22/08/2006, 16h02
  5. effacer des composants crée dynamiquement
    Par forzaxelah dans le forum Delphi
    Réponses: 7
    Dernier message: 29/06/2006, 14h14

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