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 :

Utilisation de la methode sort.


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 103
    Par défaut Utilisation de la methode sort.
    Bonjour,

    J'ai le code suivant qui fonctionne tres bien:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Set SHcomp1 = Sheets("U110")
    Set SHcomp2 = Sheets("U120")
    Set shcomp3 = Sheets("U130")
     
    SHcomp1.Activate
    SHcomp1.Columns("A:N").Sort Key1:=Range("A2"), Order1:=xlAscending, Header:=xlGuess, _
        OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom
    SHcomp2.Activate
    SHcomp2.Columns("A:N").Sort Key1:=Range("B2"), Order1:=xlAscending, Header:=xlYes, _
        OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom
    shcomp3.Activate
    shcomp3.Columns("A:N").Sort Key1:=Range("B2"), Order1:=xlAscending, Header:=xlYes, _
        OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom
    Par contre lorsque je modifie le code, de facon à éliminer les "Activate" dans le but d'optimiser le code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Set SHcomp1 = Sheets("U110")
    Set SHcomp2 = Sheets("U120")
    Set shcomp3 = Sheets("U130")
     
    SHcomp1.Columns("A:N").Sort Key1:=Range("A2"), Order1:=xlAscending, Header:=xlGuess, _
        OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom
    SHcomp2.Columns("A:N").Sort Key1:=Range("B2"), Order1:=xlAscending, Header:=xlYes, _
        OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom
    shcomp3.Columns("A:N").Sort Key1:=Range("B2"), Order1:=xlAscending, Header:=xlYes, _
        OrderCustom:=1, MatchCase:=False, Orientation:=xlTopToBottom
    J'ai le code d'erreur 1004, reference de tri non valide, pourquoi?

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    753
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 753
    Par défaut
    Toujours le même problème éternel des références implicites...

    Juste un indice: ton problème se situe au niveau de ce que tu renseignes pour ton attribut Key.

  3. #3
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Bonjour,

    En précisant juste Range("A2"), il prendra en compte la cellule A2 de la feuille active qui n'est pas forcément la feuille sur laquelle s'effectue le tri vu que n'utilises plus les "Select" (ce qui est très bien).

    Il faut donc lui préciser de quelle feuille provient la cellule A2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SHcomp1.Columns("A:N").Sort Key1:=SHcomp1.Range("A2")',...
    ou encore
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    With SHcomp1
        .Columns("A:N").Sort Key1:=.Range("A2")',... 
    End With
    Cdlt

  4. #4
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 103
    Par défaut
    Merci beaucoup pour votre aide.

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

Discussions similaires

  1. utilisation de la methode random
    Par jiji83 dans le forum Langage
    Réponses: 2
    Dernier message: 21/02/2007, 02h25
  2. Réponses: 1
    Dernier message: 01/02/2007, 11h57
  3. [debutant] Utiliser String et methodes
    Par jcaspar dans le forum Langage
    Réponses: 1
    Dernier message: 21/12/2006, 11h07
  4. [POO] Utilisation d'une methode
    Par chtom dans le forum Langage
    Réponses: 2
    Dernier message: 21/11/2006, 13h47
  5. [NumberFormat] : utilisation de la methode parse()
    Par richard_34b dans le forum Collection et Stream
    Réponses: 11
    Dernier message: 20/10/2004, 15h07

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