AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Listbox nach Datum sortieren

Ein Thema von Codix32 · begonnen am 29. Mai 2009 · letzter Beitrag vom 5. Jul 2009
Antwort Antwort
Seite 2 von 5     12 34     Letzte »    
Codix32

Registriert seit: 23. Apr 2009
137 Beiträge
 
Delphi 2005 Personal
 
#11

Re: Listbox nach Datum sortieren

  Alt 30. Mai 2009, 13:14
Zitat von Luckie:
Was ist mit miner Lösung?
DANKE LUCKIE!

Dein Code funzt einwandfrei, ich bin begeistert.

Du bist wohl auch beruflich Programmierer.
  Mit Zitat antworten Zitat
Codix32

Registriert seit: 23. Apr 2009
137 Beiträge
 
Delphi 2005 Personal
 
#12

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 12:05
Zitat von Codix32:
Zitat von Luckie:
Was ist mit miner Lösung?
DANKE LUCKIE!

Dein Code funzt einwandfrei, ich bin begeistert.

Du bist wohl auch beruflich Programmierer.
Hier bin ich wieder. Nichts für ungut, aber die Routine mit Bubblesort ist sehr sehr langsam.


Ich greife also hier wieder auf 'Listbox.sorted' zurück:
Delphi-Quellcode:
procedure TForm1.sortListe3(L:TListbox);
var i: integer;
    Zeilendatum:String;
    Zeilenrest:string;
    temp:string;
    doubleTmp:double;
begin
for i := 0 to L.items.count-1 do
begin
doubleTmp:= strtodate(copy(L.Items[i],1,10));
   temp:=floattostr(doubleTmp);
   if length(temp)=1 then temp:='000000'+temp;
   if length(temp)=2 then temp:='00000'+temp;
   if length(temp)=3 then temp:='0000'+temp;
   if length(temp)=4 then temp:='000'+temp;
   if length(temp)=5 then temp:='00'+temp;
   if length(temp)=6 then temp:='0'+temp;
ZeilenDatum:= temp;
Zeilenrest:= copy(L.Items[i],11,length(L.Items[i]));
L.Items[i]:=Zeilendatum +' '+ Zeilenrest;
end;
 
L.sorted:=true;

 for i := 0 to L.items.count-1 do
 begin
   doubleTmp:= strtofloat(Trim(copy(L.Items[i],1,10)));
   ZeilenDatum:= datetostr(doubleTmp);//+' '+floattostr(doubleTmp);
   Zeilenrest:= copy(L.Items[i],11,length(L.Items[i]));
   L.Items[i]:= Zeilendatum +' '+ Zeilenrest;
 end;
end;
Obwohl die Items durch 2 Schleifen laufen, ist damit ruckizucki sortiert. Es wird das Datum als Double-Zahlenwert an den Anfang jedes Items geschrieben, danach sortiert und in der 2. Schleife der Zahlenwert wieder entfernt.

Obwohl das 'Werk' funzt, gefällt es mir nicht. Gibts noch einen anderen Ansatz?

Ist die Delphi interne Function 'Sorted' eigentlich in Assembler geschrieben und wenn ja, wer hat den Quelltext? Die Funktion ist sehr schnell und daher interessant.

Was meint ihr?
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#13

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 14:40
Wie veiele Einträge hast du denn in der Liste, dass Bubblesort so langsam ist? Du kannst natürlcih auch jeden anderen Sortieralgorithmus nehmen. Bubblesort habe ich nur genommen, weil er relativ einfach und schnell zu implementieren ist.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Codix32

Registriert seit: 23. Apr 2009
137 Beiträge
 
Delphi 2005 Personal
 
#14

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 15:38
Zitat von Luckie:
Wie veiele Einträge hast du denn in der Liste, dass Bubblesort so langsam ist? Du kannst natürlcih auch jeden anderen Sortieralgorithmus nehmen. Bubblesort habe ich nur genommen, weil er relativ einfach und schnell zu implementieren ist.
Bei 400 Einträgen braucht die Sortierung ~20 Sekunden. Das ist zu lange. Meine Routine braucht nur etwas unter 1 Sekunde. Ich suche eine saubere Möglichkeit des Sortierens.
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#15

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 15:41
Folgendes: Setzmal den BubbleSort Aufruf in eine TListbox.BeginUpdate und TListbox.EndUpdate. Und dannkannst du noch einen besseren Sortieralgorithmus benutzen, wie zum Beispiel Quicksort oder so.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Fridolin Walther

Registriert seit: 11. Mai 2008
Ort: Kühlungsborn
446 Beiträge
 
Delphi 2009 Professional
 
#16

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 15:45
Bubble Sort ist für 400 Einträge völlig ausreichend. Das Problem, wieso es mit einer ListBox so langsam erscheint ist, daß die Operationen um die Position einzelner Strings innerhalb der Listbox zu verändern recht langsam ist, da die UI bei jeder Operation upgedated wird. Entsprechend benutz BeginUpdate und EndUpdate.

Ansonsten benutzt Delphi in so ziemlich allen VCL Komponenten, die sortieren können, QuickSort.
Fridolin Walther
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#17

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 15:51
Listbox, es geht um eine Listbox. Ändert natürlich nichts an deiner Aussage bezüglich des Neuzeichnes beim Verschieben der Einträge.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Codix32

Registriert seit: 23. Apr 2009
137 Beiträge
 
Delphi 2005 Personal
 
#18

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 16:10
Zitat von Luckie:
Folgendes: Setzmal den BubbleSort Aufruf in eine TListbox.BeginUpdate und TListbox.EndUpdate. Und dannkannst du noch einen besseren Sortieralgorithmus benutzen, wie zum Beispiel Quicksort oder so.
Danke Dir luckie,

werde das morgen mal probieren. Würde mich interessieren, was 'Listbox.sorted' für ein Algorithmus ist. Mal sehen. .-)
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#19

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 16:12
Zitat von 0xF30FC7:
Ansonsten benutzt Delphi in so ziemlich allen VCL Komponenten, die sortieren können, QuickSort.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Fridolin Walther

Registriert seit: 11. Mai 2008
Ort: Kühlungsborn
446 Beiträge
 
Delphi 2009 Professional
 
#20

Re: Listbox nach Datum sortieren

  Alt 24. Jun 2009, 16:13
Zitat von Luckie:
Listbox, es gerht um eine Listbox. Ändert natürlcih nichts an deiner Aussage bezüglich des Neuzeichnes beim Verschieben der Einträge.
Au ja ... grad gesehen. Danke für den Hinweis. Werds korrigieren .

Zitat von Codix32:
werde das morgen mal probieren. Würde mich interessieren, was 'Listbox.sorted' für ein Algorithmus ist. Mal sehen. .-)
Sagte ich bereits ... QuickSort .
Fridolin Walther
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 5     12 34     Letzte »    


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 12:07 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