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 :

variable tri sur une colonne d'une listobject


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Mars 2014
    Messages
    64
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2014
    Messages : 64
    Points : 50
    Points
    50
    Par défaut variable tri sur une colonne d'une listobject
    Bonjour,
    J'ai plusieurs tableaux listobject qui se présentent tous de la même façon. Je souhaiterai faire une macro qui me permet de les trier suivant la première colonne (qui s'appelle 'entreprise)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Public Sub Tri_oList(oList As ListObject)  
        oList.Sort.SortFields.Clear
        oList.Sort.SortFields.Add2 Key:=Range("Txl_Tel[[#All],[ENTREPRISES]]"), SortOn:=xlSortOnValues, Order:=xlAscending, DataOption:=xlSortTextAsNumbers  
        With oList.Sort
            .Header = xlYes
            .MatchCase = False
            .Orientation = xlTopToBottom
            .SortMethod = xlPinYin
            .Apply
        End With
    End Sub
    Sauf qu'il y a la présence de "Txl_Tel" que je n'arrive pas à mettre en variable (Txl_Tel étant le nom d'un tableau structuré sous excel) oList peut faire référence entre autre à Txl_Tel.

    Merci de vos réponses

  2. #2
    Membre confirmé
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Mars 2021
    Messages
    334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2021
    Messages : 334
    Points : 602
    Points
    602
    Par défaut
    Salut, tu as essayé l'enregistreur de macro ?

    Moi ça donne un truc du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Feuil16.ListObjects("data_presenteisme").Range.AutoFilter Field:=11, Criteria1:="0"
    Data_presenteisme étant le nom du tableau, feuil16 la feuille ou est présente mon tableau, field étant la colonne de mon tableau a trier et criteria1 étant le critère de tri.

    Pour faire un tri sur tous tes tableaux il faudra faire une boucle For voir même plusieurs du genre :

    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
    Sub test()
    Dim mysht As Worksheet
    Dim mytable As ListObject
    Dim myCol As ListColumn
     
    For Each mysht In ThisWorkbook.Worksheets
        For Each mytable In mysht.ListObjects
            For Each myCol In mytable.ListColumns
                If myCol.Name = "EnteteAtrier" Then
                    mytable.Range.AutoFilter Field:=myCol.Index, Criteria1:="0"
                End If
            Next myCol
         Next mytable
    Next mysht
     
    End Sub
    la condition d'entrée est le nom de ton entête (remplacer "EnteteAtrier" ), d'apres ca tu recupere l'index de ta colonne et tu effectue le tri que tu veux

  3. #3
    Expert éminent
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Points : 7 149
    Points
    7 149
    Billets dans le blog
    7
    Par défaut
    Bonsoir à vous, Bonsoir au Forum,

    Christian,

    Je ne comprends pas cette partie de ton code

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    For Each myCol In mytable.ListColumns
                If myCol.Name = "EnteteAtrier" Then
                    mytable.Range.AutoFilter Field:=myCol.Index, Criteria1:="0"
                End If
    Next myCol
    Plutôt que procéder par boucle, autant trier sur l'index de la colonne directement.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Field:=mytable.ListColumns("EnteteAtrier").Index
    VBA reconnaîtra la colonne à trier directement.

    Et ce d'autant que ta boucle continuera d'être effective APRES le tri de celle reconnue.
    Et ce du fait qu'il 'y a pas de sortie anticipée (Exitt For).

    Cela étant, mieux vaut, pour ne pas dénaturer l'emploi d'une boucle For, utiliser soit Do...Loop, soit Do...Until.

  4. #4
    Membre confirmé
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Mars 2021
    Messages
    334
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2021
    Messages : 334
    Points : 602
    Points
    602
    Par défaut
    Marcel,

    Il me semble que la demande est de boucler sur plusieurs tableaux qui ont le même entête :

    J'ai plusieurs tableaux listobject qui se présentent tous de la même façon.
    Donc le do until oui mais quelle condition de sortie ?

    Et oui j'ai fait une boucle mais implicitement je pense que VBA fait a peu près la même chose avec ce que tu propose puisque il recherche dans l'objet "listColumns" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Field:=mytable.ListColumns("EnteteAtrier").Index
    Par contre effectivement ça doit réduire le nombre d'actions à effectuer.

  5. #5
    Expert éminent
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Points : 7 149
    Points
    7 149
    Billets dans le blog
    7
    Par défaut
    Christian,

    Je voulais signifier qu'en général, afin de sortir par anticipation d'une boucle For, mieux vaut utiliser l'une des 2 boucles Do.
    Quand bien même ici, le balayage des colonnes s'effectuerait jusqu'à ce que le nom de la colonne soit trouvée. (Boucle Do)

    Cela étant, quelle qu'en soit la nature, une boucle est absolument inutile pour pointer une colonne de tableau structuré.
    C'est d'ailleurs là, l'un des grands avantages de ce type d'objet.

  6. #6
    Membre du Club
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Mars 2014
    Messages
    64
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2014
    Messages : 64
    Points : 50
    Points
    50
    Par défaut variable tri sur une colonne d'une listobject
    Bonjour à vous,

    Merci à vous pour vos réponses et mes excuses pour la mienne si tardive.

    ChristianBosch, ce que j'ai mentionné en code est justement tiré de l'enregistreur macro. C'est étonnant que nous n'ayons pas la même chose.
    Je vais en tout cas creusé vos pistes. Avec cela, je ne devrai pas être loin de trouver la solution.

  7. #7
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 940
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 12 940
    Points : 28 938
    Points
    28 938
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    J'ai plusieurs tableaux listobject qui se présentent tous de la même façon. Je souhaiterai faire une macro qui me permet de les trier suivant la première colonne (qui s'appelle 'entreprise)
    S'il s'agit de trier une colonne d'une table structurée (ListObject), la lecture de ce billet titré VBA pour Excel - Comment trier une colonne d’un tableau structuré en une ligne d’instruction, vous aidera peut-être

  8. #8
    Membre du Club
    Homme Profil pro
    Assistant aux utilisateurs
    Inscrit en
    Mars 2014
    Messages
    64
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Assistant aux utilisateurs
    Secteur : Transports

    Informations forums :
    Inscription : Mars 2014
    Messages : 64
    Points : 50
    Points
    50
    Par défaut
    IM-PEC-CABLE !

    Merci Philippe.

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 10/02/2011, 10h25
  2. [VxiR2] Tri sur une variable complexe
    Par SGA99 dans le forum Webi
    Réponses: 5
    Dernier message: 05/01/2011, 17h44
  3. 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
  4. tri sur une colonne
    Par cubepiege dans le forum Langage SQL
    Réponses: 11
    Dernier message: 13/07/2006, 12h16
  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