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

  1. #1
    Candidat au Club
    Femme Profil pro
    Agricultrice
    Inscrit en
    Mai 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 46
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Agricultrice
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mai 2014
    Messages : 5
    Points : 4
    Points
    4
    Par défaut Filtrer une BD et n'afficher dans une ListBox que les données des lignes identiques en cliquant sur un bouton
    Bonjour,
    Je souhaiterais mettre ma base de données dans un tableau puis la trier en fonction du nom d'une colonne (615) et n'afficher dans la ListBox 4 (multicolonnes) que les valeurs des lignes identiques (Case 1) en cliquant sur le bouton 12. Je me suis pour cela servie de la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FiltreArrayCléColRécup(Tbl, clé, colClé, colRécup)
    mais j'ai le message d'erreur suivant : Erreur d'exécution '424': Objet requis qui apparaît.

    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
    Private Sub CommandButton12_click()
     
    Dim a, b, feuille
    Set feuille = Sheets("CLASSEMENT")
    Set a = feuille.Range("A2:G" & f.[A65000].End(xlUp).Row).Value
      b = FiltreArrayCléColRécup(a, "Case 1", 615, Array(615, 4, 5, 6, 10, 11, 12, 17, 14))
      [p2].Resize(UBound(b), UBound(b, 2)) = b
    b = Me.ListBox4.List
     
    End Sub
     
    Function FiltreArrayCléColRécup(Tbl, clé, colClé, colRécup)
      Dim n, d As Object, c, i, k
      n = 0
      Set d = CreateObject("scripting.dictionary")
      For Each c In clé: d(c) = "": Next c
      For i = 1 To UBound(Tbl)
        If d.Exists(Tbl(i, colClé)) Then n = n + 1
      Next i
      Dim Tbl2(): ReDim Tbl2(1 To n, LBound(colRécup) To UBound(colRécup))
      n = 0
      For i = 1 To UBound(Tbl)
        If d.Exists(Tbl(i, colClé)) Then
          n = n + 1
          For k = LBound(colRécup) To UBound(colRécup): Tbl2(n, k) = Tbl(i, colRécup(k)): Next k
        End If
      Next i
      If n > 0 Then FiltreArrayCléColRécup = Tbl2
    End Function
    Pourriez-vous me dire pourquoi cela ne fonctionne pas ? Merci

  2. #2
    Membre émérite Avatar de Zekraoui_Jakani
    Homme Profil pro
    Inscrit en
    Novembre 2013
    Messages
    1 670
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Novembre 2013
    Messages : 1 670
    Points : 2 489
    Points
    2 489
    Par défaut
    A quelle ligne se produit l'erreur ?
    Conseil: transformer votre tableau en tableau structurel (insérer table dans ruban); c'est beaucoup plus pratique et peut facilement répondre à votre demande.

  3. #3
    Candidat au Club
    Femme Profil pro
    Agricultrice
    Inscrit en
    Mai 2014
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 46
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Agricultrice
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Mai 2014
    Messages : 5
    Points : 4
    Points
    4
    Par défaut
    Bonjour,

    Ci-joint le classeur :
    Classeur4.xlsm

    Lorsque je clique sur le bouton "SAUMUR", j'ai l'erreur ci-dessous qui apparaît :

    Erreur d'exécution '424' : objet requis

    Cela me met une erreur à la ligne ci-dessous :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Set a = feuille.Range("B3:J" & f.[A65000].End(xlUp).Row).Value

  4. #4
    Responsable
    Office & Excel


    Homme Profil pro
    Formateur et développeur chez EXCELLEZ.net
    Inscrit en
    Novembre 2003
    Messages
    19 122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur et développeur chez EXCELLEZ.net
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 19 122
    Points : 55 924
    Points
    55 924
    Billets dans le blog
    131
    Par défaut
    Salut.

    Tu as déclaré un objet portant le nom Feuille, et sur la ligne incriminée, tu utilises f.. Essaie ceci: Set a = feuille.Range("B3:J" & feuille.[A65000].End(xlUp).Row).Value.

    Cela dit, c'est du vieux code! "A65000" ça sent le XL2003, voire plus vieux, et une syntaxe que je te déconseille: [A65000]...

    Je suivrais le conseil de Zekraoui et je travaillerais avec un tableau structuré. Et pour correspondre à ma signature, je travaillerais avec Excel et un tableau temporaire pour éviter de manipuler un array en VBA avec tout ce que ça comporte de "niveau informatique" à comprendre.


    Cela étant, il y a d'autres erreurs dans ton code... Dans CommandButton1_Click, tu as la ligne Set a = feuille.Range("B3:J" & feuille.[A65000].End(xlUp).Row).Value, or a est un tableau, donc tu ne peux pas mettre Set devant, qui est réservé pour l'affectation de valeurs à des objets.

    Dans FiltreArrayCléColRécup, tu as For Each c In clé: d(c) = "": Next c (Très mauvaise idée, plusieurs instructions sur la même ligne, au passage) or c contient "Saumur", alors que for each requiert une collection...

    L'idée des trois boutons est à bannir. Si demain tu dois utiliser plus de villes, ça va devenir ingérable puisque tu vas devoir multiplier les codes des boutons ou passer par une classe qui les gèrent. Perso, je verrais mieux une listbox ou une combobox pour choisir la ville

    Je ne sais pas où tu as péché ce code (la syntaxe me donne bien une idée du "pondeur de code") mais il n'est pas fonctionnel, soit de façon native soit suite à tes modifications...
    "Plus les hommes seront éclairés, plus ils seront libres" (Voltaire)
    ---------------
    Mes billets de blog sur DVP
    Mes remarques et critiques sont purement techniques. Ne les prenez jamais pour des attaques personnelles...
    Pensez à utiliser les tableaux structurés. Ils vous simplifieront la vie, tant en Excel qu'en VBA ==> mon tuto
    Le VBA ne palliera jamais une mauvaise conception de classeur ou un manque de connaissances des outils natifs d'Excel...
    Ce ne sont pas des bonnes pratiques parce que ce sont les miennes, ce sont les miennes parce que ce sont des bonnes pratiques
    VBA pour Excel? Pensez D'ABORD en EXCEL avant de penser en VBA...
    ---------------

Discussions similaires

  1. [XL-2010] Alimenter une listbox avec les données d'une feuille par ordre décroissant
    Par lavineur dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 24/03/2015, 13h56
  2. [Toutes versions] Remplir une ListBox avec les données d'une autre feuille
    Par Valoche37 dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 10/01/2012, 16h25
  3. [AC-2007] Afficher dans un ListBox données d'une Table MySQL
    Par amazon dans le forum IHM
    Réponses: 3
    Dernier message: 26/08/2009, 21h04
  4. Réponses: 7
    Dernier message: 19/05/2009, 16h57
  5. Réponses: 12
    Dernier message: 22/06/2006, 12h09

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