![]() |
Muss viele Strings vergleichen. Geschwindigkeit...
Hallo,
ich habe ein kleines Problem. Ich habe bis zu 2.000.000 Produkte in CSVDateien. Dort stehen Bestellnummern drin. Bestellnummern die mehrmals vorkommen muss ich zählen. Die Bestellnummern sind 10 Zeichen lang. Da die Bestellnummern nur 10 Zeichen haben habe ich die in einer TStringlist. Das ist wesentlich schneller als THashedStringList habe ich festgestellt. Nun zu meinem Problem. Je mehr Bestellnummern ich in der TStringlist habe um so langsamer wird das ganze. Ist ja auch logisch. Ich Frage mit .IndexOf ob es die Bestellnummer schon gibt. Wenn nicht adde ich die. Hat vielleicht jemand eine andere Idee wie ich schneller abfragen könnte ob es die Nummer schon gibt? Vielen dank im Voraus |
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Mit THashedStringList sollte ein IndexOf eigentlich schneller sein.
Falls du zufällig doch eine neuere Version als Delphi 2007 benutzt gäbe es da auch noch TDictionary<string, string> (bzw. <string, irgendwas>) |
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Hast du bei der Stringlist nach dem Create
Delphi-Quellcode:
auf true gesetzt? Wenn du dann noch
Sorted
Delphi-Quellcode:
auf dupIgnore setzt, dann kannst du dir die Abfrage auf
Duplicates
Delphi-Quellcode:
auch sparen, da bei einem
IndexOf
Delphi-Quellcode:
nur ein noch nicht vorhandener String zugefügt wird.
Add
|
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Jupp, wenn StringList sortiert ist, dann nutzt IndexOf eine "optimierte" Suchfunktion,
wenn nicht, dann wird im Worst-Case jedes mal die komplette Liste durchgegangen (jeder einzelne String verglichen). Mit eine Hashed-StringList muß nur nach dem Hash (Integer) gesucht werden, anstatt alle Strings als Byteweise zu vergleichen. Das Dictinary ist erstmal sortiert und nutzt auch noch Hashs. (die Hashs sind natürlich sortiert) |
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Wir haben BTree-Implementierung im Einsatz die uns genau solche Suchen extrem beschleunigt.
|
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Zitat:
Du könntest die TStringList sortieren und auf dupError setzen. Beim Add fängst du den Fehler ab und weißt, ob der Eintrag schon in der Liste war oder nicht. |
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Add macht intern auch ein IndexOf (außer bei dupAccept und wenn nicht sortiert, wo er nicht zu prüfen/suchen braucht)
Das Tempo des IndexOf steckt also auch im Add drin. |
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Aus meiner Sicht eindeutig: versuche es erst mal mit einem TDictionary<>. Ist wirklich "Delphi 2007 Architect" deine letzte Version? Bestell dir eine neuere oder such dir einen anderen Job.
BTree geht auch, ist aber nicht "out of the Box". Falls doch: auch ich habe auch eine Implementierung incl. hausinternen unit test. |
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Zitat:
|
AW: Muss viele Strings vergleichen. Geschwindigkeit...
Zitat:
Delphi-Quellcode:
erübrigt sich das eben. Das macht intern nämlich genau das.
dupIgnore
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 23:06 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 by Thomas Breitkreuz