![]() |
Stringlist nach sortet und dupIgnore wiederherstellen
Hallo!
Delphi-Quellcode:
Eine Datei wird in eine Stringlist geladen. Nun soll ein Eintrag hinzugefügt werden, dabei ist aber auf doppelte Einträge zu achten. Aus diesem Gund musste ich die Liste zuerst sortieren.
//Stringliste neuen Eintrag hinzufügen und wieder abspeichern
sl := TStringList.create; try sl.LoadFromFile(FN_MYFILE); sl.Sorted := true; sl.Duplicates := dupIgnore; sl.Append(my_zickezacke); l.saveToFile(FN_MYFILE); finally sl.free; end; Ich möchte die Liste aber nicht alphabetisch sortiert wieder abspeichern, sondern im Urzustand lassen und lediglich den neuen Eintrag anhängen. Aberdennoch darf der anzuhängende Eintrag nicht schon in der Liste stehen. Wie löst man sowas? |
Re: Stringlist nach sortet und dupIgnore wiederherstellen
B'n'D Ansatz: Kopier dir die Liste und habe eine welche die doppelten abprüft (also sortiert ist). Wenn dort alles glatt geht, dann füge das Element in deiner Hauptliste ein.
|
Re: Stringlist nach sortet und dupIgnore wiederherstellen
Ist es nicht besser einfach alle Einträge durchzugehen, als erst die ganze Liste zu kopieren :gruebel:
Delphi-Quellcode:
sl := TStringList.create;
try sl.LoadFromFile(FN_MYFILE); if sl.indexof(my_zickezacke)<0 then sl.add(my_zickezacke); l.saveToFile(FN_MYFILE); finally sl.free; end; |
Re: Stringlist nach sortet und dupIgnore wiederherstellen
Das macht dupIgnore doch genauso, nur halt schneller, weil er eine sortierte Liste braucht. Es ist das gleiche Verhalten, aber dupIgnore ist deutlich schneller. Wenn man nun deinen und meinen Vorschlag vergleicht und man davon ausgeht, dass es hier um mehr als einen Eintrag geht, dann sollte mein Vorschlag zwar mehr Speicher verbrauchen, aber trotzdem schneller sein.
|
Re: Stringlist nach sortet und dupIgnore wiederherstellen
In dieser Liste werden nicht mehr als 200 Einträge stehen.
Das dürfte performancetechnisch nicht ins Gewicht fallen oder? |
Re: Stringlist nach sortet und dupIgnore wiederherstellen
Hmm ja. Wahrscheinlich ist es bedeutungslos, aber erst kopieren, dann sortieren und dann durchsuchen dauaert bestimmt länger als einmal (wenn auch langsamer) durchsuchen.
[roter Kasten]: Ja |
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:51 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