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

Вниз

работа с датами   Найти похожие ветки 

 
[NIKEL] ©   (2002-03-06 13:10) [0]

Надо так расчтать...
Есть год и месяц, и есть флаг, который сигнализирует о 5-ти дневном рабочем дне или 6-ти дневном. На основании этих данных, нужно расчитать количество рабочих дней в заданном месеце с учётом флага.


 
McSimm ©   (2002-03-06 13:41) [1]

Придеться перебирать. Что-то вроде:
function WorkDayCount(Y, M: Word; SatIsWork: Boolean): Integer;
var I: Integer;
W: Word;
begin
Result := 0;
for I := 1 to DaysInAMonth(Y, M) do
begin
W := DayOfWeek(EncodeDate(Y, M, I));
if (W <> 1) and ((W <> 7 ) or SatIsWork) then Inc(Result)
end
end;

Функция DaysInAMonth есть в D6. Для D5 можно написать ее:
function DaysInAMonth(const AYear, AMonth: Word): Word;
begin
Result := MonthDays[(AMonth = 2) and IsLeapYear(AYear), AMonth];
end;


 
[NIKEL] ©   (2002-03-06 13:44) [2]

все понятно, спасибо!


 
Ura   (2002-03-06 14:38) [3]

Совет...
Есть еще сокращенные дни!
Или дополнительное время работы ;-) Добровольно обязательное...



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

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

Наверх




Память: 0.47 MB
Время: 0.012 c
1-66834
Андре
2002-03-07 16:15
2002.03.21
FastReport


1-66873
HELPME
2002-03-05 18:09
2002.03.21
СРОЧНО!!!!!!!!!!!!!!!!


3-66743
draculenok
2002-02-20 07:49
2002.03.21
Отчет по нескольким линиям TMemo!!!!


14-66994
Andrey
2002-02-06 18:15
2002.03.21
Вкладка Servers


1-66918
None
2002-03-05 11:29
2002.03.21
Рисование поверх всех компонент.