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 :

Tri sur une colonne avec un critère Array


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    254
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 254
    Par défaut Tri sur une colonne avec un critère Array
    Bonjour à tous,

    Je cherche un moyen de filtrer un tableau Excel à l'aide d'un Array. J'ai essayé une multitude de solutions mais impossible de trouver la bonne !
    Le but de ce filtre est de filtrer toutes les lignes NE correspondant PAS au array.

    Pour le moment j'ai essayé ça : (Tout le code n'y est pas, mais toutes les variables sont déclarées)

    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
     
    option explicit
     
    sub Tri
     
    Dim C1 As String, C2 As String, C3 As String, C4 As String, C5 As String, C6 As String
    Dim C7 As String, C8 As String, C9 As String, C10 As String, C11 As String, C12 As String
    Dim C13 As String, C14 As String
     
    C1 = WsPrev.Range("A5")
    C2 = WsPrev.Range("A6")
    C3 = WsPrev.Range("A7")
    C4 = WsPrev.Range("A8")
    C5 = WsPrev.Range("A9")
    C6 = WsPrev.Range("A10")
    C7 = WsPrev.Range("A11")
    C8 = WsPrev.Range("A12")
    C9 = WsPrev.Range("A13")
    C10 = WsPrev.Range("A14")
    C11 = WsPrev.Range("A15")
    C12 = WsPrev.Range("A16")
    C13 = WsPrev.Range("A17")
    C14 = WsPrev.Range("A18")
     
    LigneBase = WsBase.Cells(Rows.Count, 1).End(xlUp).Row
     
    WsBase.Range("A11:A" & LigneBase).AutoFilter field:=23, Criteria1:="<>" & Array(C1, C2, C3, C4, C5, C6, C7, C8, C9, C10, C11, C12, C13, C14), Operator:=xlAnd
    Mais malheureusement, erreur d'exécution 13 : Incompatibilité de type

    Si vous voyez l'erreur, n'hésitez plus !

  2. #2
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 974
    Par défaut
    bonjour
    c'est le travail de philipe tuliziez
    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
    Sub FiltreInverseListe()
      Set f1 = Sheets("feuil1")
       Set f3 = Sheets("feuil2")
      Set d = CreateObject("scripting.dictionary")
      d.CompareMode = vbTextCompare
     
      Dim liste As New Collection
       Dim i As Integer
       On Error Resume Next
       For Each cel In f3.Range("A2:A" & [A65000].End(xlUp).Row)
        If Cells(cel.Row, 2) = "" Then
        liste.Add cel.Value, CStr(cel.Value)
        End If
       Next cel
      For Each c In liste: d(c) = "": Next c
      Set f2 = Sheets("feuil1")
      Set d2 = CreateObject("scripting.dictionary")     ' liste complémentaire
      d2.CompareMode = vbTextCompare
      For Each c In f2.Range("A2:A" & f2.[A65000].End(xlUp).Row)
       If Not d.exists(c.Value) Then d2(c.Value) = ""
      Next c
      ActiveSheet.Range("$A$1:$A$10").AutoFilter Field:=1, Criteria1:=d2.keys, Operator:=xlFilterValues
    End Sub
    Fichiers attachés Fichiers attachés

  3. #3
    Membre expérimenté
    Homme Profil pro
    Étudiant
    Inscrit en
    Octobre 2018
    Messages
    254
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 29
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Octobre 2018
    Messages : 254
    Par défaut
    Bonjour Bennasr,

    Je t'avouerai que la partie Dictionnary je n'y connais absolument rien du tout mais ça à l'air plutôt puissant !

    Merci pour ta réponse ! Je vais me pencher là dessus

    Par contre en attendant que je maîtrise ça, il n'y aurait pas un autre moyen de répondre à mon petit souci ?

  4. #4
    Membre extrêmement actif
    Homme Profil pro
    Inscrit en
    Septembre 2013
    Messages
    1 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Septembre 2013
    Messages : 1 369
    Par défaut
    Bonjour,

    Cf https://www.developpez.net/forums/d1...e-d-exclusion/

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    Sub FiltreInverseListe()
      Set f1 = Sheets("feuil1")
      Set d = CreateObject("scripting.dictionary")
      d.CompareMode = vbTextCompare
      liste = Array("paris", "lyon", "bordeaux")            ' Liste à ne pas sélectionner
      For Each c In liste: d(c) = "": Next c
      Set f2 = Sheets("feuil1")
      Set d2 = CreateObject("scripting.dictionary")     ' liste complémentaire
      d2.CompareMode = vbTextCompare
      For Each c In f2.Range("B2:B" & f2.[B65000].End(xlUp).Row)
       If Not d.exists(c.Value) Then d2(c.Value) = ""
      Next c
      ActiveSheet.Range("$A$1:$B$100").AutoFilter Field:=2, Criteria1:=d2.keys, Operator:=xlFilterValues
    End Sub
    Faire une recherche Google: excel vba filtre inverse array

    Boisgontier
    Fichiers attachés Fichiers attachés

Discussions similaires

  1. Réponses: 2
    Dernier message: 20/10/2014, 10h15
  2. Tri sur une colonne d'un champs calculé DBGRID
    Par BuzzLeclaire dans le forum Bases de données
    Réponses: 13
    Dernier message: 18/02/2009, 15h13
  3. tri sur une colonne
    Par cubepiege dans le forum Langage SQL
    Réponses: 11
    Dernier message: 13/07/2006, 12h16
  4. Réponses: 16
    Dernier message: 10/11/2005, 22h51
  5. [JSP] tri sur une colonne
    Par soony dans le forum Servlets/JSP
    Réponses: 6
    Dernier message: 28/07/2005, 15h02

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