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 :

Désélectionner les éléments sélectionnés dans une ListBox à sélection multiple [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

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

    Informations forums :
    Inscription : Avril 2007
    Messages : 840
    Par défaut Désélectionner les éléments sélectionnés dans une ListBox à sélection multiple
    Bonjour

    Après de multiples recherches, je ne trouve pas la solution, voilà le problème.

    Dans un formulaire qui contient 2 Listbox, si c'est des Listbox à sélection simple (donc, sans sélection multiple) un simple MaListe=Null suffit pour désélectionner l'élément sélectionné dans la Listbox précédemment utilisée.

    Par contre si les 2 Listbox sont à sélection multiple, lorsque je passe d'une Listbox à l'autre, l'élément ou les éléments sélectionnés dans la Listbox précédemment utilisée restent sélectionnés en surbrillance dans la liste.

    Comment désélectionner l'élément ou les éléments sélectionnés ou supprimer la surbrillance dans la Listbox précédemment utilisée lorsque j'en sélectionne un ou plusieurs dans l'autre Listbox .

    Merci d'avance pour aide

  2. #2
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Bonjour,

    dans le cadre d'un listbox à multiselection, il faut parcourir la collection des éléments et les déselectionner

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Private Sub CommandButton1_Click()
        With Me.ListBox1
            For i = 1 To .ListCount
               .Selected(i - 1) = False
            Next i
        End With
    End Sub

  3. #3
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    salut joe
    il y a beaucoup plus simple
    réinitialiser la listbox par la listbox

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub CommandButton1_Click()
    ListBox1.List = ListBox1.List
    End Sub
    voila
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  4. #4
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    Yes tu as raison

    En fait, à mes torts exclusifs, je pensais deviner un non-dit potentiel dans son explication : une possibilité d'ajouter par la suite un "transfert" d'une liste à l'autre, qui nécessite là d'identifier les éléments sélectionnés.

    d'où la présentation de Selected(x)

    mais à froid, en relisant, je crois que j'ai vu trop loin pour rien

  5. #5
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    re
    c'est pas un tord il a une vision globale des possibilités maintenant


    1. aperçu de méthode (transfert)
    2. désélection de tous
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    840
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 840
    Par défaut
    Bonjour et merci à vous.

    Ça fonctionne avec les 2 solutions, celle de Patrick est plus simple et comporte qu'une ligne de code.

    Bravo pour votre réactivité

    Ma réponse s'est entre croisée, je prends note de la réponse de joe si besoin de transfert.

  7. #7
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2007
    Messages
    840
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2007
    Messages : 840
    Par défaut
    Bonsoir.

    Je n'ai pas résolu mon problème, en effet avec un CommandButton1_Click pas de soucis.

    Par contre ça ne fonctionne pas dans un ListBox1_Click en multi sélection ?

    Ce que je veux faire :
    - Désélectionner l'élément ou les éléments sélectionnés dans la ListBox1 (MultiSelect = fmMultiSelectMulti) lorsque je clicque dans la ListBox2 (MultiSelect = fmMultiSelectMulti) pour sélectionner un plusieurs ou plusieurs éléments.

    Existe-t-il une solution ?

  8. #8
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    tu peux nous montrer toutes ces procédures ?

    je devine peut-être le problème, mais en VBA on ne devine pas, on analyse et on démontre

  9. #9
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut re
    re
    je crois qu'on l'a perdu Joe entre 2 item
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  10. #10
    Expert confirmé

    Homme Profil pro
    Curieux
    Inscrit en
    Juillet 2012
    Messages
    5 169
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Curieux
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Juillet 2012
    Messages : 5 169
    Billets dans le blog
    5
    Par défaut
    J'ai toute confiance en Patrick (qui a osé rigoler ? )

    De mon côté, je ne suis pas en mesure de continuer sans l'élément demandé

    Citation Envoyé par joe.levrai Voir le message
    tu peux nous montrer toutes ces procédures ?
    la question est de vider une sélection dans un ListBox, via l'évènement d'un autre contrôle (lui-même un ListBox)
    du coup, la question étant assez ciblée et généraliste, le fichier ne sert à rien, les procédures contenues dans ton Userform vont suffire amplement à voir où est ton problème (mauvais évènement, mauvaise méthode, mauvais contrôle sur lequel on utilise l'évènement etc...), il suffit de les copier dans un message

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

Discussions similaires

  1. [Débutant] Retrouver les items sélectionnés dans une listbox
    Par Shennong dans le forum VB.NET
    Réponses: 3
    Dernier message: 16/05/2014, 16h02
  2. Réponses: 2
    Dernier message: 19/04/2013, 11h03
  3. Réponses: 13
    Dernier message: 21/05/2012, 15h46
  4. Réponses: 1
    Dernier message: 29/07/2010, 16h10
  5. Réponses: 5
    Dernier message: 05/10/2006, 10h18

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