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 :

Recherche sur Format + resultat dans Listbox de Userform


Sujet :

Macros et VBA Excel

Vue hybride

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

    Informations forums :
    Inscription : Septembre 2008
    Messages : 9
    Par défaut Recherche sur Format + resultat dans Listbox de Userform
    Bonjour,

    A partir d'un userform, je souhaite lancer une recherche des cellules de toutes les feuilles de mon classeur dont la couleur de font est rouge. Je récupère au fur et à mesure la liste des cellules dans une Listbox de mon Userform
    Voici le code que j'utilise et qui ne fonctionne pas :
    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
    Private Sub CommandButton1_Click()
    Dim WS As Worksheet
    Dim Plage As Range, Cell As Range
    Dim Adresse As String
    Dim Ligne As Variant
    Dim C As Object
    ListBox1.Clear
     
    Application.FindFormat.Font.ColorIndex = 3
     
    For Each WS In Worksheets
    Ligne = Worksheets(WS.Name).Range("" & "E" & "65536").End(xlUp).Row
    Set Plage = Worksheets(WS.Name).Range("" & "E" & "2:" & "E" & Ligne)
         With Plage
        Set C = .Find("*", SearchFormat:=True)
        If Not C Is Nothing Then
            Adresse = C.Address
                Do
                    ListBox1.AddItem C
                    Set C = .FindNext(C)
                Loop While Not C Is Nothing And C.Address <> Adresse
            End If
        'Next C
    End With
    Next WS
    End Sub
    Cela m'affiche toutes les cellules non vides de la colonne E, que la police soit rouge ou non.

    Si je supprime le * dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set C = .Find("", SearchFormat:=True)
    La recherche se lance et ne s'arrête plus.

    Merci pour votre aide ou vos conseils.

  2. #2
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    Bonjour,

    si j'ai compris, tu cherches une fond rouge, le find ?????
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    sub Couleur()
    Dim ws as worksheet, ligne as long, c as range, plage as range
    For Each WS In Worksheets
    Ligne = WS.Range("" & "E" & "65536").End(xlUp).Row
    Set Plage = WS.Range("" & "E" & "2:" & "E" & Ligne)
         For each c in plage
               if c.interior.colorindex = 3 then
                    ListBox1.AddItem C
               End If
         Next C
    Next WS
    End Sub

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    9
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 9
    Par défaut
    Merci de ta réponse,

    Ce n'est pas le fond, mais la font (police) qui est rouge.
    J'ai modifié le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if c.interior.colorindex = 3 then
    par le suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If C.Font.ColorIndex = 3 Then
    et cela fonctionne

    Merci à toi

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

Discussions similaires

  1. Lister fichiers de dossier dans listbox ou userform
    Par ericdev67 dans le forum Macros et VBA Excel
    Réponses: 13
    Dernier message: 26/05/2013, 09h18
  2. [MySQL] Recherche sur cinq caractères dans champ Bdd
    Par casimirine dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 14/05/2013, 11h20
  3. Réponses: 0
    Dernier message: 03/09/2010, 10h48
  4. [VB6]Comment inserer plusieurs infos sur meme ligne dans listbox ?
    Par angelevil dans le forum VB 6 et antérieur
    Réponses: 25
    Dernier message: 31/05/2006, 19h03
  5. Recherche sur 2 elements dans une liste box.
    Par molarisapa dans le forum Access
    Réponses: 2
    Dernier message: 29/05/2006, 18h43

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