![]() |
Re: TreeView mit 200.000 Einträge und nachladen
Moment mal bitte, ich würde doch erst einmal darüber nachdenken, wer 200.000 (in Worten: zweihundertausend) Einträge mehr oder weniger lesen möchte -> ich nicht! Also ist es wahrschenlich besser, sich Gedanken über die Einteilung der Einträge in bestimmte Kategorien zu machen und das ganze Problem so lange zu unterteilen, bis eine lesbare Verteilung entsteht, oder :gruebel: !
|
Re: TreeView mit 200.000 Einträge und nachladen
Deswegen wird es mit dem Nachladen von Zweigen nicht schneller, auch wenn Sie nur noch 5000 Einträge haben. Und 5000 Einträge sind nicht unrealistisch.
Mit der TreeView-Variante werden alle 5000 Einträge geladen. Mit der virtuellen Variante nur die sichtbaren 50. (Je nachdem, wir groß das Control ist). |
Re: TreeView mit 200.000 Einträge und nachladen
Ich möchte auch keine 5000 Einträge lesen (maximal 50)!
|
Re: TreeView mit 200.000 Einträge und nachladen
Praktisches Beispiel:
Leistungsverzeichnis mit mehreren Titeln (Knoten). Die untersten Titelebenen enthalten jeweils rund 2000 Positionen. Die wird man sicher durchlesen und mit Preisen verpassen müssen, auch wenn man nicht will. |
Re: TreeView mit 200.000 Einträge und nachladen
Zitat:
|
Re: TreeView mit 200.000 Einträge und nachladen
Die schnellste Möglichkeit, den Baum dynamisch nachzuladen ist die, die Datei korrekt zu sortieren, sodaß Du relativ fix die nachzuladenden Knoten ermitteln kannst. Du kannst versuchen, die Bauminformation in einer einfach TStringlist zu laden. Das ist relativ fix.
Wenn Du nun einen Knoten expandieren willst, dann suchst Du das erste 'Kind' der neuen Unterebene. Ab da liest Du aus der Stringliste einfach alle Elemente dieser Ebene ein. Eine Stringliste mit 200.000 Elementen durchzulaufen geht innerhalb von ein paar ms, also kein Problem. Wichtig ist, das Du anhand eines Schlüssel erkennst, welche Knoten zusammengehören, und das sehe ich bei deinem Verfahren nicht. Für die Root-Ebene ist das einfach '00', aber für die Kinder des 3.Rootknotens ist das nicht gegeben. Deshalb wäre es ratsam, Jedem Knoten eine ID zu geben, und zwar so (rekursiv definiert):
Delphi-Quellcode:
Nach dieser ID sortierst Du die Stringliste.
Function ID (Knoten)
If Knoten = Nil Then Result := '' Else Result := ID (Knoten.Parent)+'/'+Knoten.Index Um nun alle Kinder eines Knotens mit einer bestimmten ID 1/2/3 zu laden, suchst Du einfach den Eintrag 1/2/3/0. Das ist das erste Kind. Ab da gehst Du sequentiell in der Stringliste weiter (die ist ja nach der ID sortiert), bis die einzulesende ID nicht mehr dem Muster 1/2/3/* entspricht. Das sollte ohne Verzögerungen gehen. Ich teste das gleich mal und poste dann hier (wenn ich mich nicht zum Horst mache), eine Demo. |
Re: TreeView mit 200.000 Einträge und nachladen
ich glaube nicht das das windows control treeview soviele einträge verkraftet oder performat darstellen kann.
ich empfehle dir auf dem virtualstringtree umzusteigen. diesen gibt es hier: ![]() |
Re: TreeView mit 200.000 Einträge und nachladen
--> ich glaube nicht das das windows control treeview soviele einträge verkraftet oder performat darstellen kann.
Aber klar doch verkraftet die TV soviele Einträge! Ich habs doch schon durchprobiert. Nur die Ladezeiten stören mic wirklich. --> Kroko... Liest Du dir ein ganzes Lexikon durch um den Begriff "Dumm" zu finden oder schaust du unter "D" nach? Und wenn Du noch wissen willst, woher das Wort kommt, so - stöbern und begreifen - lieste Dir dann noch was ethnomythologisches durch? Bischen dümmlich, Deine Maxime... ---> generic Ich hab nur ne offizielle D5, und keine alte VirtuTV Version. Theme wird nicht unterstützt und ich kaufe mir für 200.000 Eiträge nicht ne neue Version. Die alte ist mühsamer, aber für das was ich will, reicht sie in allen Bereichen. Ist nur Bei - nicht Hauptwerk. ---> alzaimar Erstma Danke, und ich hoffe, Horst hat Ruhe. Das Indizieren der Zugehörigkeit ist nicht so wild, das ist bloß Schreibarbeit. Die Daten liegen vor und ich kann sie verbiegen, wie ich will. Danke |
Re: TreeView mit 200.000 Einträge und nachladen
Liste der Anhänge anzeigen (Anzahl: 1)
Zitat:
Derzeit habe ich eine Verzögerung von 200-300ms (PM 1.5Ghz) bei jedem Klick, wenn der Knoten noch nicht befüllt wurde), bei 200.000 Einträgen. Das ist schon ganz ordendlich. Man kann es auf fast 0ms Verzögerung reduzieren, wenn man die Baum-Information geeignet ablegt. Dann geht das Suchen sehr schnell. Die Bottlenecks lassen sich auf zwei Routinen reduzieren: 1. Ist ein Texteintrag ein Kindknoten eines vorgegeben Knotens? 2. Existieren für einen Knoten überhaupt Kinder? Wenn die Bauminformation so gespeichert wird, das der Index des Vaters für jeden Knoten mit abgespeichert wird, dann kann man (1) vernachlässigen. Wenn die Anzahl der Kinder auch gespeichert wird, dann wird auch (2) vernachlässigbar. Beide Optimierungsmöglichkeiten sind in dieser Demo nicht berücksichtigt. Man könnte es aber ohne Weiteres einbauen. Ich würde die Baumdaten auch nicht als Text, sondern als geeignete Struktur ablegen (in einem Stream, z.B.) dann geht das Laden und Suchen sehr schnell, eigentlich ohne Verzögerung. |
Re: TreeView mit 200.000 Einträge und nachladen
Zitat:
D -> DU -> DUM -> DUMM gefunden. Meine Maxime mag eigen sein, bestimmt nicht dümmlich (PS: Toller Tonfall über andere Meinungen), aber glaubst Du wirklich jemand liest sich bei voller Konzentration 2000 Einträge durch? NIE MALS, überprüfe Dich doch mal selbst! Die Strategie "TEILE und HERRSCHE" entstand nicht einfach so, sondern .. naja. @jaikai Trotzdem finde ich Deinen Tonfall nicht gut, aber wenn Du es so haben möchtest, erstelle Dein Programm mit soviel Einträgen, wie Du willst, auf meine Hilfe zähle nicht mehr! |
Alle Zeitangaben in WEZ +1. Es ist jetzt 19:58 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz