Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.07.25;
Скачать: CL | DM;

Вниз

Разность между датами   Найти похожие ветки 

 
Vlad Schekunov   (2002-07-14 06:05) [0]

Здравствуйте все!
Проблема такая: есть две даты (дата поступления - дата увольнения). Нужно получить разность между ними в формате: кол-во_лет, кол-во_месяцев, кол-во_дней. Может кто-нибудь подскажет алгоритм? Заранее благодарен.


 
MBo ©   (2002-07-14 10:44) [1]

Вопрос задается через день. Стоит поискать по форуму


 
TTCustomDelphiMaster ©   (2002-07-14 11:46) [2]

procedure CalcDateDelta(lDate, hDate: TDate; var dYear, dMonth, dDay: word);
var
yy1, yy2, mm1, mm2, dd1, dd2: word;
begin
if hDate > lDate then
begin
decodedate(lDate, yy1, mm1, dd1);
decodedate(hDate, yy2, mm2, dd2);
if (mm1>mm2) or ((mm1=mm2) and (dd1>dd2)) then
begin
dYear := yy2 - yy1 - 1;
dMonth := 12 - mm1 + mm2;
end
else
begin
dYear := yy2 - yy1;
dMonth := mm2 - mm1;
end;
if dd1>dd2 then
dec(dMonth);
dDay := trunc(hDate -
incmonth(lDate, dYear * 12 + dMonth));
end
else
begin
dYear := 0;
dMonth := 0;
dDay := 0;
end;
end;



Страницы: 1 вся ветка

Текущий архив: 2002.07.25;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.012 c
14-81414
VuDZ
2002-06-26 19:58
2002.07.25
Is this Pascal?


3-81199
Grrey
2002-07-02 18:46
2002.07.25
Классическая ситуация


1-81293
Socol
2002-07-12 10:14
2002.07.25
Проблема с TMemo


6-81398
Rouse
2002-05-04 00:01
2002.07.25
Fireboll


3-81165
KAA
2002-07-04 11:09
2002.07.25
2000 Warning: Null value is eliminated by an aggregate or