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

Windows Discussion :

Remplissage rapide d'une Listbox


Sujet :

Windows

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 10
    Points : 8
    Points
    8
    Par défaut Remplissage rapide d'une Listbox
    Bonjour

    Quelqu'un a t'il une idee pour remplir rapidement une Listbox (Ma listbox contient plus de 1 millions d'item)

    J'ai essayé un tas de chose mais rien à faire, ca rame (+ de 10 mn pour ajouter 1 millions d'items)

    J'ai essayé quelques astuces trouvées sur le forum sans plus de succes

    J'ai essayé de remplacer la ListBox par une ListView (C'est pire)

    Je suis preneur de toutes idées meme farfelus

    merci pour vos reponses

    NoopTax

  2. #2
    Inactif  
    Avatar de Mac LAK
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    3 893
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 3 893
    Points : 4 846
    Points
    4 846
    Par défaut


    Un million d'entrées dans une listbox, tu as conscience de la faille de conception monstrueuse là-dedans ??
    D'une part, c'est une quantité de RAM colossale qui est nécessaire. D'autre part, qui pourrait être assez masochiste pour scroller parmi un million d'entrées pour choisir sa donnée ???

    Expliques plutôt ce que tu cherches à faire, il y a plus que certainement une bien meilleure solution à ton problème qu'une listbox surchargée d'éléments...
    Mac LAK.
    ___________________________________________________
    Ne prenez pas la vie trop au sérieux, de toutes façons, vous n'en sortirez pas vivant.

    Sources et composants Delphi sur mon site, L'antre du Lak.
    Pas de question technique par MP : posez-la dans un nouveau sujet, sur le forum adéquat.

    Rejoignez-nous sur : Serveur de fichiers [NAS] Le Tableau de bord projets Le groupe de travail ICMO

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 10
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Mac LAK Voir le message


    Un million d'entrées dans une listbox, tu as conscience de la faille de conception monstrueuse là-dedans ??
    D'une part, c'est une quantité de RAM colossale qui est nécessaire. D'autre part, qui pourrait être assez masochiste pour scroller parmi un million d'entrées pour choisir sa donnée ???

    Expliques plutôt ce que tu cherches à faire, il y a plus que certainement une bien meilleure solution à ton problème qu'une listbox surchargée d'éléments...

    Bon, c'est clair que ca rame un petit chouille et que ca bouffe quelque Mega de ram, mais c'est pas mechant...

    Une fois la liste chargée, mon appli fonctionne parfaitement !

    Cela dit je suis preneur d'autre solution pour entrer plusieurs millions d'elements

  4. #4
    Inactif  
    Avatar de Mac LAK
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    3 893
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 3 893
    Points : 4 846
    Points
    4 846
    Par défaut
    Citation Envoyé par nooptax Voir le message
    Bon, c'est clair que ca rame un petit chouille et que ca bouffe quelque Mega de ram, mais c'est pas mechant...
    C'est plutôt rédhibitoire, je trouve...

    Citation Envoyé par nooptax Voir le message
    Une fois la liste chargée, mon appli fonctionne parfaitement !
    Sérieusement, tu parses réellement la liste d'un million d'entrées manuellement ??

    Citation Envoyé par nooptax Voir le message
    Cela dit je suis preneur d'autre solution pour entrer plusieurs millions d'elements
    Pour ça, il te faut expliciter le besoin initial, donc dire ce que tu cherchais à faire... Par exemple, "autocomplétion de données" ? "Sélection de fichier" ?
    Mac LAK.
    ___________________________________________________
    Ne prenez pas la vie trop au sérieux, de toutes façons, vous n'en sortirez pas vivant.

    Sources et composants Delphi sur mon site, L'antre du Lak.
    Pas de question technique par MP : posez-la dans un nouveau sujet, sur le forum adéquat.

    Rejoignez-nous sur : Serveur de fichiers [NAS] Le Tableau de bord projets Le groupe de travail ICMO

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 10
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Mac LAK Voir le message
    C'est plutôt rédhibitoire, je trouve...

    Sérieusement, tu parses réellement la liste d'un million d'entrées manuellement ??

    Pour ça, il te faut expliciter le besoin initial, donc dire ce que tu cherchais à faire... Par exemple, "autocomplétion de données" ? "Sélection de fichier" ?
    J'ai essayé d'autres solutions qui ne me vont pas... trop complexe !
    Le truc simple, c'est la listbox, Combox
    Reste plus qu'a trouver un truc pour accelerer le remplissage

    Je te rassure, le remplissage est automatique à partir d'un fichier, lui meme crée automatiquement

    Merci quand meme

  6. #6
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Mais comment l'utilisateur est-il supposé chercher ce qu'il veut dedans?
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  7. #7
    Inactif  
    Avatar de Mac LAK
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    3 893
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 3 893
    Points : 4 846
    Points
    4 846
    Par défaut
    Citation Envoyé par nooptax Voir le message
    J'ai essayé d'autres solutions qui ne me vont pas... trop complexe !
    C'est que tu n'as pas trouvé LA bonne solution, c'est tout.

    Citation Envoyé par nooptax Voir le message
    Reste plus qu'a trouver un truc pour accelerer le remplissage
    Il n'y en a pas, c'est lié à la structure / nature même de la combobox qui n'est PAS prévue pour gérer un machin pareil.

    Citation Envoyé par nooptax Voir le message
    Je te rassure, le remplissage est automatique à partir d'un fichier, lui meme crée automatiquement
    Ce qui ne répond pas à ma question : que voulais-tu faire à l'origine ?
    Mac LAK.
    ___________________________________________________
    Ne prenez pas la vie trop au sérieux, de toutes façons, vous n'en sortirez pas vivant.

    Sources et composants Delphi sur mon site, L'antre du Lak.
    Pas de question technique par MP : posez-la dans un nouveau sujet, sur le forum adéquat.

    Rejoignez-nous sur : Serveur de fichiers [NAS] Le Tableau de bord projets Le groupe de travail ICMO

  8. #8
    Membre éprouvé
    Avatar de maxim_um
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    895
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 895
    Points : 1 018
    Points
    1 018
    Par défaut
    Citation Envoyé par Mac LAK Voir le message
    Ce qui ne répond pas à ma question : que voulais-tu faire à l'origine ?
    Un menu déroulant ???

  9. #9
    Inactif  
    Avatar de Mac LAK
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    3 893
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 3 893
    Points : 4 846
    Points
    4 846
    Par défaut
    Citation Envoyé par maxim_um Voir le message
    Un menu déroulant ???
    Non, ça, c'est la solution envisagée...

    Il y a toujours un "but premier" à une manip / implémentation, c'est celle-là que je veux qu'il nous donne... Je citais par exemple l'autocomplétion ou la sélection de fichiers comme hypothèses possibles.
    Mac LAK.
    ___________________________________________________
    Ne prenez pas la vie trop au sérieux, de toutes façons, vous n'en sortirez pas vivant.

    Sources et composants Delphi sur mon site, L'antre du Lak.
    Pas de question technique par MP : posez-la dans un nouveau sujet, sur le forum adéquat.

    Rejoignez-nous sur : Serveur de fichiers [NAS] Le Tableau de bord projets Le groupe de travail ICMO

  10. #10
    Membre éprouvé
    Avatar de maxim_um
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    895
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 895
    Points : 1 018
    Points
    1 018
    Par défaut
    Citation Envoyé par Mac LAK Voir le message
    Non, ça, c'est la solution envisagée...
    Non, non ! C'est surtout une blague.

  11. #11
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 10
    Points : 8
    Points
    8
    Par défaut
    Citation Envoyé par Mac LAK Voir le message
    C'est que tu n'as pas trouvé LA bonne solution, c'est tout.

    Il n'y en a pas, c'est lié à la structure / nature même de la combobox qui n'est PAS prévue pour gérer un machin pareil.

    Ce qui ne répond pas à ma question : que voulais-tu faire à l'origine ?
    Voici la solution que j'ai trouvé :

    1 - Definir la list avec le style Ownerdraw et non Hasstring
    2 - Empecher le rafraichissement de la list avec SetRedraw
    3 - Utiliser SetItemData avec Addstring

    Resultat : Le chargement d'un millions d'item se fait en moins de 1 minute !
    Ce qui me convient tout à fait

  12. #12
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Mais tu n'as pas répondu à la question:
    Citation Envoyé par Médinoc Voir le message
    Mais comment l'utilisateur est-il supposé chercher ce qu'il veut dedans?
    Si tu réponds à cette question, on pourra te dire ce qui est vraiment approprié pour ça.
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  13. #13
    Inactif  
    Avatar de Mac LAK
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    3 893
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations forums :
    Inscription : Octobre 2004
    Messages : 3 893
    Points : 4 846
    Points
    4 846
    Par défaut
    Citation Envoyé par nooptax Voir le message
    Resultat : Le chargement d'un millions d'item se fait en moins de 1 minute !
    Une minute de chargement d'une IHM pour se retrouver avec une liste ingérable, c'est malgré tout bien trop...

    S'il te plait : réponds à la question que je t'ai déjà posée plusieurs fois, il y a de très très grandes chances que l'on te trouve une solution bien plus efficace pour ton problème initial.

    De manière générale, lisez les réponses que l'on fait, et répondez aux questions que l'on pose même si elles ne vous paraissent pas importantes. Les erreurs de conception, c'est bien plus courant qu'on ne le pense...
    Mac LAK.
    ___________________________________________________
    Ne prenez pas la vie trop au sérieux, de toutes façons, vous n'en sortirez pas vivant.

    Sources et composants Delphi sur mon site, L'antre du Lak.
    Pas de question technique par MP : posez-la dans un nouveau sujet, sur le forum adéquat.

    Rejoignez-nous sur : Serveur de fichiers [NAS] Le Tableau de bord projets Le groupe de travail ICMO

  14. #14
    Membre éprouvé
    Avatar de maxim_um
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    895
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 895
    Points : 1 018
    Points
    1 018
    Par défaut
    salut Mac LAK,
    salut Médinoc;

    Dans la mesure où il s'en moque complètement, laissez-le faire. Après tout, ce n’est pas notre problème.
    Franchement, avec ce genre de comportement, il n'y a pas lieu de s'attarder plus sur cette discussion.
    Il pourrait au moins dire que c'est " secret défense ".

    Et puis si ça se trouve, il n'avait pas plus de dix mille éléments et il voulait faire son intéressant.

  15. #15
    Membre à l'essai
    Inscrit en
    Mars 2006
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 19
    Points : 17
    Points
    17
    Par défaut
    salut
    j'imagine que tu ne cherches plus, mais sinon moi je suis tombé sur cet exemple sur codeguru:

    http://www.codeguru.com/cpp/controls...cle.php/c4197/

Discussions similaires

  1. remplissage laborieux d'une listBox
    Par philippe6 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 18/10/2013, 20h26
  2. [Débutant] Remplissage d'une listbox via une requete SQL
    Par arngrimur dans le forum ASP.NET
    Réponses: 9
    Dernier message: 26/09/2011, 11h31
  3. [AC-2003] Remplissage d'une ListBox avec des éléments d'un Recordset
    Par Sclarckone dans le forum VBA Access
    Réponses: 4
    Dernier message: 10/08/2011, 13h40
  4. Remplissage d'une ListBox selon affichage dans Combo
    Par NEC14 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 26/07/2010, 15h52
  5. remplissage d'une listbox
    Par nabilfaouzi dans le forum ASP.NET
    Réponses: 1
    Dernier message: 24/02/2009, 01h35

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