Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Date Vergleich (https://www.delphipraxis.net/179691-date-vergleich.html)

mcbain 25. Mär 2014 07:40

Delphi-Version: 5

Date Vergleich
 
Hallo,
ich habe ein seltsames Problem.
Ich vergleiche Dates miteinander und bekomme auf unterschiedlichen Systemen unterschiedliche Ergebnisse:
Beispielsweise überprüfe ich ob ein Ereignis innerhalb eines Zeitraumes liegt.
Mein Code:
Code:
...
var start: TDate;
    ende: TDate;
    ereignis: TDate;
begin
...

if (ereignis >= start) and
   (ereignis <= ende) then

...
Auf Maschine 1 funktioniert das korrekt.
Auf Maschine 2 läuft er mir einen Tag zu spät in die Schleife, wenn start gleich ereignis ist.

Wenn ich mit CompareDate arbeite läufts bei beiden Maschinen.
Hat jemand eine Idee warum das so ist?

Vielen Dank.
Gruß
mc

DeddyH 25. Mär 2014 07:57

AW: Date Vergleich
 
AFAIK enthalten auch TDate-Variablen einen Zeitanteil. Funktioniert es, wenn Du den jeweils mit DateOf nullst?
Delphi-Quellcode:
if (DateOf(ereignis) >= DateOf(start)) and
   (DateOf(ereignis) <= DateOf(ende)) then

Perlsau 25. Mär 2014 08:07

AW: Date Vergleich
 
Stimmt, hab's eben ausprobiert: Mit DateOf(Datum) erfolgt die Berechnung korrekt. TDate ist tatsächlich vom Typ TDateTime, das wiederum vom Typ Double ist.
Delphi-Quellcode:
procedure TFormMain.Button1Click(Sender: TObject);
Var
  start,
  ende,
  ereignis : TDate;
  Aus     : String;

begin
  start   := DateOf(StrToDate('01.03.2014'));
  ende    := DateOf(StrToDate('30.04.2014'));
  ereignis := DateOf(DateTimePicker1.Date);

  if (ereignis >= start) and
     (ereignis <= ende) then
     Aus := 'innerhalb' else
     Aus := 'außerhalb';

  ShowMessage(Aus);
end;

Sir Rufo 25. Mär 2014 08:11

AW: Date Vergleich
 
Das ist nicht seltsam, sondern liegt in der Natur der Sache begründet.

Delphi-Referenz durchsuchenTDate ist ein Delphi-Referenz durchsuchendouble und somit ein FloatingPoint-Type, und durch die systembedingten Ungenauigkeiten (nicht alle Werte können wirklich korrekt dargestellt werden) werden FloatingPoint-Werte immer auf Ähnlichkeit (mit einem Epsilon = maximale Abweichung) und nicht auf absolute Gleichheit geprüft.

Delphi-Referenz durchsuchenCompareDate berücksichtigt dieses eben ;)

baumina 25. Mär 2014 09:10

AW: Date Vergleich
 
Zitat:

Zitat von Sir Rufo (Beitrag 1253367)
Delphi-Referenz durchsuchenCompareDate berücksichtigt dieses eben ;)

Ja, CompareDate macht ein Trunc.

Sir Rufo 25. Mär 2014 10:31

AW: Date Vergleich
 
Zitat:

Zitat von baumina (Beitrag 1253374)
Zitat:

Zitat von Sir Rufo (Beitrag 1253367)
Delphi-Referenz durchsuchenCompareDate berücksichtigt dieses eben ;)

Ja, CompareDate macht ein Trunc.

Wie das dort berücksichtigt wird ist egal, solange es korrekt ist ;)

mcbain 25. Mär 2014 10:38

AW: Date Vergleich
 
Vielen Dank für eure Antworten.
ich dachte mir ursprünglich auch, dass es an einem Zeitanteil scheitern könnte, aber da der Typ ja nicht Datetime sondern Date ist, dachte ich der Zeitanteil wird dabei ignoriert.

Alles klar, dann werde ich in Zukunft vergleiche mit CompareDate machen.

himitsu 25. Mär 2014 11:58

AW: Date Vergleich
 
TDate und TTime haben grundsätzlich erstmal nur syntaktischen Charakter, also mehr für den Programmierer.

Intern sind TDateTime, TDate und TTime alle gleich (Double) und könnten sowohl Uhrzeit, als auch Datum enthalten. (wenn derjenige nicht aufpasst, welcher diese Typen/Variablen mit Werten füllt)

sx2008 25. Mär 2014 17:12

AW: Date Vergleich
 
TDateTimePicker hat schon seit ewigen Zeiten einen Bug.
Wenn man das
Delphi-Quellcode:
Property [TDateTimePicker].Date
abfragt würde man ja erwarten dass man nur den Datumsanteil bekommt.
Schlieslich gibt es auch noch die Properties
Delphi-Quellcode:
DateTime
und
Delphi-Quellcode:
Time
.
Man bekommt aber das Datum + aktuelle Uhrzeit zurück.
Abhilfe bringt die Zeile:
Delphi-Quellcode:
ereignis := DateOf(DateTimePicker1.Date);
Die anderen DateOf() bei StrToDate() braucht man nicht.

Möglicherweise hat man sich später nicht mehr getraut diesen Bug abzustellen weil dies existierenden Code brechen könnte...

himitsu 25. Mär 2014 17:43

AW: Date Vergleich
 
Ich glaub den Bug hat man inzwischen sogar "schon" behoben. (in irgendeinem der XEs)


Alle Zeitangaben in WEZ +1. Es ist jetzt 12:55 Uhr.
Seite 1 von 2  1 2      

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