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 :

effacer toutes les checkbox d'une sheet


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 59
    Par défaut effacer toutes les checkbox d'une sheet
    Bonjour à tous!
    Parmi plein de formes différentes dans une sheet(menus en listes, case options,etc..)j'ai un grand nombre de checkbox dans cette page excel et je voudrais insérer une fonction VBA qui les supprime toutes (et uniquement les checkboxes) lorsque je clique sur un bouton affecté à la macro correspondante. Je sais qu'il faut utiliser une commande "for each controls in...etc." mais je ne maitrise pas trop le "controls()" et j'ai peur d'effacer toutes les formes de ma page!
    Quelqu'un aurait-il une idée?
    Merci!
    Bonne journée

  2. #2
    Membre Expert Avatar de Jean-Pierre49
    Homme Profil pro
    Retraité
    Inscrit en
    Juillet 2007
    Messages
    659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2007
    Messages : 659
    Par défaut
    Bonjour,

    Une piste dans le cas ou les checkbox ne sont pas renommés.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
                                Dim ControleRecherche                   As Shape
     
        For Each ControleRecherche In ActiveSheet.Shapes
            If Left(ControleRecherche.Name, 9) = "Check Box" Then ControleRecherche.Delete
        Next

  3. #3
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Bonjour,

    Une autre piste éventuelle
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Sub test()
    Dim CB As OLEObject
     
    For Each CB In ActiveSheet.OLEObjects
    If TypeOf CB.Object Is MSForms.CheckBox Then CB.Delete
    Next
    End Sub

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    59
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 59
    Par défaut
    Ok, ca marche!
    Merci beaucoup!

  5. #5
    Membre Expert Avatar de Jean-Pierre49
    Homme Profil pro
    Retraité
    Inscrit en
    Juillet 2007
    Messages
    659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 70
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2007
    Messages : 659
    Par défaut
    Bonjour fring

    Ton Code ne fait rien chez moi, a tu une idée,

    Néanmoins, récupérer avec F1 et adapté

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
                                Dim Cb                   As Shape
     
    For Each Cb In ActiveSheet.Shapes
        If Cb.Type = msoFormControl Then
            If Cb.FormControlType = xlCheckBox Then Cb.Delete
        End If
    Next
    Fonctionne bien

  6. #6
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Oui exact Jean-Pierre...j'ai oublié une petite précision, je n'utilise jamais la barre à outils "Formulaires" pour insérer les objets mais toujours la "Boîte à outils Contrôles" dont les objets offrent beaucoup plus de possibilités quant à leurs utilisations dans VBA.

    D'où la différence entre les deux codes mais c'est bien d'avoir mis le doigt dessus

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

Discussions similaires

  1. [JSF]Cocher toutes les checkbox d'une colonne
    Par Shivan dans le forum JSF
    Réponses: 6
    Dernier message: 14/07/2009, 19h09
  2. Réponses: 0
    Dernier message: 27/11/2007, 22h59
  3. Réponses: 7
    Dernier message: 30/05/2006, 11h00
  4. Effacer toutes les données d'une colonne
    Par denisfavre dans le forum Access
    Réponses: 5
    Dernier message: 12/10/2005, 15h20
  5. Pb effacer toutes les tables d'une bd access
    Par madiam2004 dans le forum Bases de données
    Réponses: 5
    Dernier message: 30/05/2004, 15h24

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