Menu

Tri personnalisé [Résolu/Fermé]

julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention - 9 avril 2017 à 08:28 - Dernière réponse : julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention
- 10 avril 2017 à 14:05
Bonjour,
Je souhaiterai appliquer un tri Az sur une plage en fonction d'une colonne , jusque là pas de soucis ;
Le probléme est que les mises en formes des lignes ne se déplacent pas
Une bonne volonté pour m'aiguiller?

le fichier d'exemple
http://www.cjoint.com/c/GDjgwIYDOZQ
merci beaucoup

Afficher la suite 

12 réponses

Vaucluse 22003 Messages postés lundi 23 juillet 2007Date d'inscriptionContributeurStatut 22 mai 2018 Dernière intervention - 9 avril 2017 à 09:44
0
Utile
Bonjour
mise en forme conditionnelle, peut être:
  • effacer la mise en forme actuelle
  • sélectionner A1:X12
  • MFC par formule:

=LIGNE()=12 formater jaune
  • idem pour les autres N° de lignes et couleurs assorties


crdlmnt
julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention - 9 avril 2017 à 10:32
0
Utile
Merci pour la proposition
J'aurai souhaité par contre une solution vba car le tri se trouve au milieu de procédures vba de création et d'exploitation d'une base de données

Bien merci
Vaucluse 22003 Messages postés lundi 23 juillet 2007Date d'inscriptionContributeurStatut 22 mai 2018 Dernière intervention - 9 avril 2017 à 11:27
Alors bonne chance, VBA ce n'est pas mon domaine
crdlmnt
julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention - 9 avril 2017 à 11:32
0
Utile
Merci d'voir essayé
je vais quand meme potasser sur votre prosition ave la MFC car j'ai l'impression que excel 10 ne permet pas le tri avec format
cordialement
Vaucluse 22003 Messages postés lundi 23 juillet 2007Date d'inscriptionContributeurStatut 22 mai 2018 Dernière intervention - 9 avril 2017 à 12:18
Je peux juste dire que le tri ou le filtre par couleur de cellule ou de police fonctionne sur 2013
Si ça ne convient pas, peut être baser la MFC sur une numérotation des lignes, dans une colonne supplémentaire pour la trier avec.

Bonne route
crdlmnt
julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention - 9 avril 2017 à 14:08
0
Utile
ok ca marche
Frenchie83 1790 Messages postés lundi 6 mai 2013Date d'inscription 13 mai 2018 Dernière intervention - 9 avril 2017 à 16:42
0
Utile
Bonjour
Un essai avec l'utilisation de VBA
http://www.cjoint.com/c/GDjoQoOVZiw
Cdlt
julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention - 10 avril 2017 à 09:54
0
Utile
Bonjour

Tres bonne approche qui répond tout à fait à la problématique
Seulement , le traitement est bigrement long sur ma plage de base de données d'environ 200 lignes et les colonnes allant jusqu'a "JXY"

merci de votre aide
Frenchie83 1790 Messages postés lundi 6 mai 2013Date d'inscription 13 mai 2018 Dernière intervention - 10 avril 2017 à 10:17
0
Utile
Bonjour
Avec le blocage des calculs intermédiaires, on gagne un peu de temps.
Option Compare Text
Sub Tri()
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
    deb = Timer
    For i = 8 To 190
        For j = 8 To 190
            If Cells(j, "F") > Cells(j + 1, "F") Then
                Range(Cells(j, "F"), Cells(j, "JXY")).Copy Destination:=Range(Cells(1, "F"), Cells(1, "JXY"))
                Range(Cells(j + 1, "F"), Cells(j + 1, "JXY")).Copy Destination:=Range(Cells(j, "F"), Cells(j, "JXY"))
                Range(Cells(1, "F"), Cells(1, "JXY")).Copy Destination:=Range(Cells(j + 1, "F"), Cells(j + 1, "JXY"))
            End If
        Next j
    Next i
    Range(Cells(1, "F"), Cells(1, "JXY")).Clear
    Application.Calculation = xlCalculationAutomatic
    MsgBox "durée: " & Timer - deb
End Sub

Si ça vous convient.
Cdlt
julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention - 10 avril 2017 à 10:36
0
Utile
J'obtiens une durée de traitement à 110,14
C'est trop long .

merci
Frenchie83 1790 Messages postés lundi 6 mai 2013Date d'inscription 13 mai 2018 Dernière intervention - 10 avril 2017 à 12:48
0
Utile
Désolé, j'ai tenté autre chose mais les résultats ne sont guère meilleurs.
Je sais que 110 secondes c'est long, mais vu ce que vous demandez (conservation des couleurs et divers formats utilisés dans les cellules), cela nécessite quelques manipulations gourmandes en ressources.
Je remets le code avec le nombre de ligne indéterminé. Peut-être que quelqu'un aura une meilleure idée.
Sub Tri()
    Application.ScreenUpdating = False
    Application.Calculation = xlCalculationManual
    deb = Timer
    DerLig = [F10000].End(xlUp).Row
    For i = 8 To DerLig - 1
        For j = 8 To DerLig - 1
            If Cells(j, "F") > Cells(j + 1, "F") Then
                Range(Cells(j, "F"), Cells(j, "JXY")).Copy Destination:=Range(Cells(1, "F"), Cells(1, "JXY"))
                Range(Cells(j + 1, "F"), Cells(j + 1, "JXY")).Copy Destination:=Range(Cells(j, "F"), Cells(j, "JXY"))
                Range(Cells(1, "F"), Cells(1, "JXY")).Copy Destination:=Range(Cells(j + 1, "F"), Cells(j + 1, "JXY"))
            End If
        Next j
    Next i
    Range(Cells(1, "F"), Cells(1, "JXY")).Clear
    Application.Calculation = xlCalculationAutomatic
    MsgBox "durée: " & Timer - deb
End Sub

Cdlt
julia Namor 391 Messages postés jeudi 27 mars 2014Date d'inscription 18 mai 2018 Dernière intervention - 10 avril 2017 à 14:05
0
Utile
Merci en tout cas
déja avec le dernier code on arrive à 14 secondes de traitement
C'est toujours mieux
Je reste toujours ouverte à toute autre proposition
Bien cordialement