Главная страница
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.011 c
1-66882
DeNNiss
2002-03-05 14:44
2002.03.21
Вопрос


3-66775
tovSuhov
2002-02-21 10:58
2002.03.21
Необходим ли первичный ключ?


1-66895
der
2002-03-06 08:23
2002.03.21
круговерть с DLL


1-66870
MaxSit
2002-03-04 20:32
2002.03.21
MDIChild в DLL


1-66839
MystiX
2002-03-07 20:24
2002.03.21
XP стиль