Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Stringlist nach sortet und dupIgnore wiederherstellen (https://www.delphipraxis.net/108523-stringlist-nach-sortet-und-dupignore-wiederherstellen.html)

Ajin 15. Feb 2008 12:22


Stringlist nach sortet und dupIgnore wiederherstellen
 
Hallo!

Delphi-Quellcode:
//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;
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.

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?

Muetze1 15. Feb 2008 12:25

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.

sirius 15. Feb 2008 12:54

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;

Muetze1 15. Feb 2008 12:58

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.

Ajin 15. Feb 2008 13:10

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?

sirius 15. Feb 2008 13:19

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 05:03 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz