Want to protect your cyber security and still get fast solutions? Ask a secure question today.Go Premium

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 303
  • Last Modified:

Days passed since..

I need a function to give me how many days have passed
since a given data. It has to keep in mind about different
data formats.

Thanks.
0
bryan7
Asked:
bryan7
1 Solution
 
kretzschmarCommented:
>It has to keep in mind about different data formats.

just transform it into tdatetime

function DaysBetween(d1,d2 : TDateTime) : Integer;
begin
  result := Abs(trunc(d1-d2));
end;

meikl ;-)

0
 
Ivanov_GCommented:

  yep, kretzschmar is right, but let me add something... you don't need the Abs function because ...

  TDateTime is real number. The integer part represent the days after 12/30/1899. So trunc(d1-d2) will give you the number of days... This can me negative value ...
0
 
kretzschmarCommented:
>This can me negative value ...

i added abs, to avoid negative values :-))
0
What does it mean to be "Always On"?

Is your cloud always on? With an Always On cloud you won't have to worry about downtime for maintenance or software application code updates, ensuring that your bottom line isn't affected.

 
Ferruccio AccalaiSenior developer, analyst and customer assistance Commented:
guys the DaysBetween function already exists in DateUtils.pas that gives the integer value of the difference between 2 dates...

also it contain DaySpan function that gets the difference included the frac part of entire day...

from Delphi help:

Call DaysBetween to obtain the difference, in days, between two TDateTime values.

DaysBetween counts only whole days. Thus, DaysBetween reports the difference between Dec 31, 1999 11:59 PM and Jan 1, 2000 11:58 PM as 0 because the difference is one minute short of an entire day.

Call DaySpan to obtain the difference, in days, between two TDateTime values. Unlike the DaysBetween function, which only counts whole days, DaySpan reports incomplete days as a fraction of an entire day.
0
 
kretzschmarCommented:
i know, f68 :-))
0
 
kretzschmarCommented:
just to say, that DateUtils.pas is not on all delphi versions available
0
 
kretzschmarCommented:
function DaySpan(d1,d2 : TDateTime) : Double;
begin
  result := Abs(d1-d2);
end;

meikl ;-)
0
 
bryan7Author Commented:
Ahh thanks, that was easier than I thought eheh.
EncodeTime will do the rest. Btw my delphi5 enterprise
doesn't include that unit :(

grats kretzs on the first working answer

Thanks all for the help :)
0

Featured Post

[Webinar On Demand] Database Backup and Recovery

Does your company store data on premises, off site, in the cloud, or a combination of these? If you answered “yes”, you need a data backup recovery plan that fits each and every platform. Watch now as as Percona teaches us how to build agile data backup recovery plan.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now