firstworkdate — скрипт и функция диаграммы
Функция firstworkdate возвращает самую позднюю дату начала, при которой период, заданный в поле no_of_workdays (понедельник-пятница), окончится не позднее даты, заданной в поле end_date, с учетом возможных выходных. Поля end_date и holiday должны быть действительными датами или метками времени.
Синтаксис:
firstworkdate(end_date, no_of_workdays [, holiday] )
Тип возврата данных: целое число
Аргументы:
Аргумент | Описание |
---|---|
end_date | Метка времени даты окончания для оценки. |
no_of_workdays | Количество рабочих дней, которое должно быть получено. |
holiday |
Периоды выходных дней для исключения из рабочих дней. Период выходных дней указан как дата начала и дата окончания, разделенные запятыми. Пример: '25/12/2013', '26/12/2013' Можно исключить несколько периодов выходных дней, разделенных запятыми. Пример: '25/12/2013', '26/12/2013', '31/12/2013', '01/01/2014' |
Примеры и результаты:
В этих примерах используется формат даты DD/ММ/YYYY. Формат даты указан в операторе SET DateFormat в верхней части скрипта загрузки. Измените формат в примерах согласно своим пожеланиям.
Пример 1:
firstworkdate ('29/12/2014', 9)
Возвращает 17/12/2014.
Пример 2:
firstworkdate ('29/12/2014', 9, '25/12/2014', '26/12/2014')
Возвращает 15/12/2014, поскольку учитывается двухдневный период выходных.
Пример 3:
Добавьте образец скрипта в свой документ и запустите. Затем добавьте на лист документа как минимум поля, указанные в столбце с результатами, чтобы увидеть результаты.
ProjectTable:
LOAD *, recno() as InvID INLINE [
EndDate
28/03/2015
10/12/2015
5/2/2016
31/3/2016
19/5/2016
15/9/2016
] ;
NrDays:
Load *,
FirstWorkDate(EndDate,120) As StartDate
Resident ProjectTable;
Drop table ProjectTable;
Результирующая таблица показывает возвращенные значения функции FirstWorkDate для каждой записи в таблице.
InvID | EndDate | StartDate |
---|---|---|
1 | 28/03/2015 | 13/10/2014 |
2 | 10/12/2015 | 26/06/2015 |
3 | 5/2/2016 | 24/08/2015 |
4 | 31/3/2016 | 16/10/2015 |
5 | 19/5/2016 | 04/12/2015 |
6 | 15/9/2016 | 01/04/2016 |