Главная страница
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.008 c
6-66947
Torn
2002-01-05 16:47
2002.03.21
Сети


14-67012
Fellomena
2002-02-07 11:51
2002.03.21
Вчера первый раз напилась - сегодня так хреново с утра (всё ещё хреново).


1-66824
MetallAdm
2002-03-07 12:59
2002.03.21
Ну просто ламерский вопрос :))


1-66907
Афоня
2002-03-05 09:09
2002.03.21
Перехват сообщений из другого приложения


1-66840
Squall
2002-03-07 17:02
2002.03.21
КОМПАНЕНТА с XP STYLE!!! Где ДОСТАТЬ?