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

VBScript Discussion :

Trier une feuille excel avec entête


Sujet :

VBScript

  1. #1
    Membre éclairé
    Homme Profil pro
    retraité
    Inscrit en
    Juillet 2011
    Messages
    386
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 79
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Juillet 2011
    Messages : 386
    Par défaut Trier une feuille excel avec entête
    bonjour
    j'ai essayé de voir des exemples de tri avec entête sans parvenir à réussir mon tri.
    celui-ci se fait sur la colonne 3
    comme suit :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     Const xlascending   = 1 
     Const xlGuess	= 0
     	 Set xlapp = CreateObject("Excel.Application")
                 xlapp.Visible           = True
             Set wk = xlapp.Workbooks.Open(fic, 0,True)
    	 Set ws = wk.Sheets(1)
    	       ws.activate
                   ws.UsedRange.Select
       		xlapp.selection.Sort   ws.Range("C2"),   xlAscending ,,,,,  xlGuess
    je pense que c'est le nombre de virgules qui ne fonctionne pas!

  2. #2
    Modérateur
    Avatar de l_autodidacte
    Homme Profil pro
    Retraité : Directeur de lycée/Professeur de sciences physiques
    Inscrit en
    Juillet 2009
    Messages
    2 420
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Retraité : Directeur de lycée/Professeur de sciences physiques
    Secteur : Enseignement

    Informations forums :
    Inscription : Juillet 2009
    Messages : 2 420
    Par défaut
    La procédure(Sub) suivante pourrait faire le boulot. L'ajout d'un fichier n'est là que pour tester le résultat du tri (l'ordre ascendant étant celui par défaut) :
    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
    28
    29
    30
    31
    32
    Public Sub SortTable()
        Const xlGuess = 0, ForWriting = 2
        Dim fso, Fich,  Cnt, Table()
        Dim XL, WB, Sht, I, S
        S = ""
        Set XL = CreateObject("Excel.Application") 
        XL.Visible = True
        XL.DisplayAlerts = False 
        Set WB = XL.Workbooks.Open("C:\Test.xls")
        Set Sht = WB.Worksheets(1)
        'Syntaxe :
        'expression.Sort(Key1, Order1, Key2, Type, Order2, Key3, Order3, Header, OrderCustom, MatchCase, Orientation, SortMethod, DataOption1, DataOption2, DataOption3)
        Sht.Range("B1").Sort Sht.Columns("B"), , , , , , , xlGuess
     
        Set fso = CreateObject("Scripting.FileSystemObject")
        Set Fich = fso.OpenTextFile("Sortie.txt", ForWriting, True)
        Cnt = Sht.UsedRange.Rows.Count
        ReDim Table(0)
        For I = 2 To  Cnt ' On commenc à 2 pour préserver l'entête de colonne
         With Sht  
           Fich.WriteLine .Cells(I, 1) & "  =>  " & .Cells(I, 2)
           ReDim Preserve Table(I-2)
           Table(I-2) = .Cells(I, 2)
         End With 
        Next 
        Fich.Close
       'Enregistrement ou non ?
        If MsgBox("Enregistrer les modification ?",vbYesNo+vbInformation,"Enregistrer " & WB.Name) = vbYes Then WB.Save
     
        XL.Quit
        Set XL = Nothing
    End Sub
    Ne pas oublier le tag si satisfait.
    Voter pour toute réponse satisfaisante avec pour encourager les intervenants.
    Balises CODE indispensables. Regardez ICI
    Toujours utiliser la clause Option Explicit(VBx, VBS ou VBA) et Ne jamais typer variables et/ou fonctions en VBS.
    Vous pouvez consulter mes contributions
    Ne pas oublier de consulter les différentes FAQs et les Cours/Tutoriels VB6/VBScript
    Ne pas oublier L'Aide VBScript et MSDN VB6 Fr

  3. #3
    Membre éclairé
    Homme Profil pro
    retraité
    Inscrit en
    Juillet 2011
    Messages
    386
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 79
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Juillet 2011
    Messages : 386
    Par défaut
    Merci, cela fonctionne;
    mais je me demande quand même pourquoi ma version ne tenait pas compte de l'entête !!!

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

Discussions similaires

  1. Sélection d'une feuille excel avec une listbox
    Par felibelle dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 25/07/2022, 17h27
  2. Insérer une feuille Excel avec macro dans une page HTML
    Par Pakkaï dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 08/12/2006, 17h40
  3. trier une feuille excel en VBscript
    Par gritche dans le forum VBScript
    Réponses: 1
    Dernier message: 07/07/2006, 09h33
  4. Dupliquer une feuille Excel avec Delphi 7
    Par loci dans le forum Delphi
    Réponses: 1
    Dernier message: 01/07/2006, 15h38
  5. ecrire sur une feuille excel avec Asp
    Par Ajay dans le forum ASP
    Réponses: 7
    Dernier message: 06/01/2006, 23h18

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