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 Ordre Croissant


Sujet :

Macros et VBA Excel

  1. #1
    Candidat au Club
    Homme Profil pro
    Webmaster
    Inscrit en
    Septembre 2018
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster
    Secteur : Transports

    Informations forums :
    Inscription : Septembre 2018
    Messages : 3
    Par défaut Tri Ordre Croissant
    Bonjour,

    Je voulais savoir si il était possible de trié par ordre croissant des cellules d'un tableau. Je connais la formule : Columns("A:A").Select Selection.Sort Key1:=Range("A1")
    Cependant dans mon cas le tableau est scindé en plusieurs groupe et je veux que ce tri se fasse uniquement au sein des groupes et non dans toute la feuille. Je vous envoie un fichier Excel pour vous expliquer ce que je souhaite réaliser.
    Fichiers attachés Fichiers attachés

  2. #2
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Citation Envoyé par Hayr0x Voir le message
    Je voulais savoir si il était possible de trié par ordre croissant des cellules d'un tableau. Je connais la formule : Columns("A:A").Select Selection.Sort Key1:=Range("A1")
    Première chose : Select/Selection est inutile, voir même préjudiciable.
    Ecris plutôt :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Columns("A:A").Sort Key1:=Range("A1")
    Normalement cette méthode tri par ordre croissant.
    Si tu veux faire un tri par ordre décroissant, regarde le paramètre Order1.
    https://docs.microsoft.com/fr-fr/off...cel.Range.Sort
    https://docs.microsoft.com/en-us/off...el.xlsortorder

    Cependant dans mon cas le tableau est scindé en plusieurs groupe et je veux que ce tri se fasse uniquement au sein des groupes et non dans toute la feuille.
    Dans ce cas, il ne faut pas appliquer le Sort à la colonne entière mais à la zone Range correspondant à ce que tu souhaites trier.

    Je vous envoie un fichier Excel pour vous expliquer ce que je souhaite réaliser.
    Lis ceci : https://www.developpez.net/forums/d8...s-discussions/

  3. #3
    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,


    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 Tri()
      Set début = Range("A1")
      Ncol = début.CurrentRegion.Columns.Count
      début.Offset(, Ncol).EntireColumn.Insert Shift:=xlToRight
      Set Rng1 = début.CurrentRegion.Offset(, Ncol - 1).Resize(, 1)
      Set Rng2 = début.CurrentRegion.Offset(, Ncol).Resize(, 1)
      Rng2.Value = Rng1.Value
      Rng2.SpecialCells(xlCellTypeBlanks).FormulaR1C1 = "=R[-1]C"
      Rng2.Value = Rng2.Value
      début.CurrentRegion.Sort Key1:=Cells(2, Ncol + 1), Order1:=xlAscending, _
          Key2:=Cells(2, 1), Order2:=xlAscending, Header:=xlGuess
      Cells(1, Ncol + 1).EntireColumn.Delete
      [A1].Select
    End Sub

    Boisgontier

Discussions similaires

  1. [XL-2013] Tri ordre croissant avec problème des doublons
    Par ussparasunki dans le forum Excel
    Réponses: 5
    Dernier message: 20/12/2014, 18h41
  2. tri ordre croissant ?
    Par sniper59 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 15/04/2009, 12h28
  3. Tri par ordre croissant
    Par KinF dans le forum Algorithmes et structures de données
    Réponses: 18
    Dernier message: 13/12/2008, 20h19
  4. Tri d'un tableau par ordre croissant
    Par goaks dans le forum Algorithmes et structures de données
    Réponses: 46
    Dernier message: 29/06/2007, 16h41

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