Главная страница
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.02 c
3-66803
EN
2002-02-23 01:42
2002.03.21
Администрирование БД IB


1-66894
Baz
2002-03-05 15:25
2002.03.21
Посылание сообщений


1-66857
PlaZZma
2002-03-05 12:22
2002.03.21
Как ловить жмаканья клавиш?


3-66776
iz
2002-02-22 12:34
2002.03.21
Работа с датой и ВРЕМЕНЕМ


14-66960
maks_f
2002-02-05 10:33
2002.03.21
структура файла excel