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

VBA Access Discussion :

[VBA-A] Trie alphabétique sur un tableau unidimensionnel


Sujet :

VBA Access

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Avril 2003
    Messages : 36
    Points : 34
    Points
    34
    Par défaut [VBA-A] Trie alphabétique sur un tableau unidimensionnel
    Bonjour à tous,

    Voilà après une recherche qui n’a rien donnée, je viens vers vous pour vous demander de l’aide.
    Alors mon problème est le suivant : je voudrais faire un trie d’un tableau de " string " par ordre alphabétique. Et le problème c’est que dans VBA il n’existe pas la fonction "Array.Sort".
    J’ai essayé sur la toile de trouver une ébauche de code mais cela est rester infructueux.
    Ou bien je suis tombé sur une archive du Forum Développez avec un code de Mr Caféine (Celebre pour ces tutaux géniaux) qui faisait un trie sur plusieurs champs (trop compliquer pour mon modeste niveau)
    Voilà si vous avez dans vos cartons une ébauche de code je suis preneur.

    Merci de votre aide si précieuse.

    Bourbaky

  2. #2
    Expert confirmé
    Avatar de zazaraignée
    Profil pro
    Étudiant
    Inscrit en
    Février 2004
    Messages
    3 174
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2004
    Messages : 3 174
    Points : 4 085
    Points
    4 085
    Par défaut
    S'agit-il d'un tableau en mémoire ou d'un Range sur une feuille ?

    Pour un tableau en mémoire, faut le faire à bras. Fais une recherche sur le forum, dans les FAQ ou dans les source pour trouver un Algorithme de tri.

    S'il s'agit de données sur une feuille de calcul, enregistre une macro qui fait le tri à l'aide du bouton Tri (ascendant ou descendant, selon) de la barre d'outils.

  3. #3
    Inactif  
    Avatar de jmfmarques
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    3 784
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 3 784
    Points : 4 674
    Points
    4 674
    Par défaut
    Si le tri l'embête : il y a une méthode simple : Envoyer les éléments du tableau dans une listbox invisible avec sa propriété sorted = True puis reconstituer le tableau par une boucle.

  4. #4
    Expert confirmé
    Avatar de zazaraignée
    Profil pro
    Étudiant
    Inscrit en
    Février 2004
    Messages
    3 174
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2004
    Messages : 3 174
    Points : 4 085
    Points
    4 085
    Par défaut
    J'y avais pas pensé, à celle-là!

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Tu penses à rien...
    S'il s'agit de données sur une feuille de calcul,
    Y'en a dans Access ?

  6. #6
    Inactif  
    Avatar de jmfmarques
    Profil pro
    Inscrit en
    Décembre 2005
    Messages
    3 784
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2005
    Messages : 3 784
    Points : 4 674
    Points
    4 674
    Par défaut
    Comme moi, j'ai lu, je cite :
    c’est que dans VBA il n’existe pas la fonction "Array.Sort".

  7. #7
    Expert confirmé
    Avatar de zazaraignée
    Profil pro
    Étudiant
    Inscrit en
    Février 2004
    Messages
    3 174
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2004
    Messages : 3 174
    Points : 4 085
    Points
    4 085
    Par défaut
    Mouais, je viens juste de voir qu'il s'agit d'Access. Honte sur moi...

  8. #8
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Points : 15 546
    Points
    15 546
    Par défaut
    Ton tri se fait sur des strings, ok, mais sont-ce des données alphabétiques ou peuvent-elles comporter des chiffres ?

    A+

  9. #9
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Points : 20 147
    Points
    20 147
    Par défaut
    bonsoir

    j'espere que cette macro pourra t'aider


    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
    'tri croissant du tableau de synthese
    For i = 1 To UBound(tabSynthese)
        x = i
     
        For k = x + 1 To UBound(tabSynthese)
        If tabSynthese(k) <= tabSynthese(x) Then x = k
        Next k
     
        If i <> x Then
        ValTemp = tabSynthese(x): tabSynthese(x) = _
        tabSynthese(i): tabSynthese(i) = ValTemp
        End If
    Next i
     
     
    'controle le résultat du tri dans la fenetre d'execution
    For i = 1 To UBound(tabSynthese)
    Debug.Print tabSynthese(i)
    Next i


    bonne soiree
    michel

  10. #10
    Membre éprouvé
    Avatar de méphistopheles
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    1 551
    Détails du profil
    Informations personnelles :
    Âge : 37
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 1 551
    Points : 1 218
    Points
    1 218
    Par défaut
    tu peu aussi prendre celle-ci (quicksort, beaucoup plus rapide (O( ln(x)) je crois)( au lieu de O( x ))):http://developpez.net/forums/showthread.php?t=121524

  11. #11
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    36
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Avril 2003
    Messages : 36
    Points : 34
    Points
    34
    Par défaut Merci beaucoup
    Ca marche super bien !

    Merci à toi SilkyRoad, j'ai utilisé ton code.
    Celui donnée par Méphistophélès à l'air bien aussi je l'étudierais à mes heures perdu car je n'ai pas de contrainte de performance compte tenu du peu d'enregistrement que j'ai a trier...
    Merci à tous les membres de Développez, ce site est vraiment le meilleur !
    A très bientôt.

    Cordialement Bourbaky

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

Discussions similaires

  1. [XL-2007] Tri étendu par ordre alphabétique sur un tableau aux dimensions dynamiques
    Par atk_49 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 17/03/2014, 15h03
  2. [VBA] Trie alphabétique
    Par jackfred dans le forum Excel
    Réponses: 2
    Dernier message: 04/07/2007, 09h24
  3. [VBA] VBA et filtre sur un tableau
    Par Sergio63 dans le forum SDK
    Réponses: 1
    Dernier message: 30/03/2007, 10h27
  4. [VBA-E] Trie de données sur 2 feuilles
    Par Deejoh dans le forum Macros et VBA Excel
    Réponses: 15
    Dernier message: 22/02/2006, 16h53
  5. [VBA-E] Dim dynamique sur un tableau
    Par Vince69 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 12/12/2002, 13h32

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