30.11.2006, 04:26
общий
это ответ
Здравствуйте, Darina!
Вот модуль обработки, в принципе можно переделать на ваше усмотрение чтобы выполнялось при запуске системы
№1 Это просто по дням рождения:
//*******************************************
// Процедура генерации запроса Сформировать.
//
Процедура Сформировать()
Перем Запрос, ТекстЗапроса, Таб;
//Создание объекта типа Запрос
Запрос = СоздатьОбъект("Запрос");
ТекстЗапроса =
"//{{ЗАПРОС(Сформировать)
|Наименование = Справочник.Сотрудники.Наименование;
|ДатаРождения = Справочник.Сотрудники.ФизЛицо.ДатаРождения;
|Группировка Наименование;
|"//}}ЗАПРОС
;
// Если ошибка в запросе, то выход из процедуры
Если Запрос.Выполнить(ТекстЗапроса) = 0 Тогда
Возврат;
КонецЕсли;
// Подготовка к заполнению выходных форм данными запроса
Таб = СоздатьОбъект("Таблица");
Таб.ИсходнаяТаблица("Сформировать");
// Заполнение полей "Заголовок"
Таб.ВывестиСекцию("Заголовок");
Состояние("Заполнение выходной таблицы...");
Таб.Опции(0, 0, Таб.ВысотаТаблицы(), 0);
Пока Запрос.Группировка(1) = 1 Цикл
Год = ДатаГод(Запрос.ДатаРождения);
Месяц = ДатаМесяц(Запрос.ДатаРождения);
День = ДатаЧисло(Запрос.ДатаРождения);
ТекГод = ДатаГод(РабочаяДата());
ТекМесяц = ДатаМесяц(РабочаяДата());
ТекДень = ДатаЧисло(РабочаяДата());
Если (День = ТекДень) и (Месяц = ТекМесяц) Тогда
Возраст = ТекГод - Год;
// Заполнение полей Наименование
Таб.ВывестиСекцию("Наименование");
КонецЕсли
КонецЦикла;
// Вывод заполненной формы
Таб.ТолькоПросмотр(1);
Таб.Показать("Сформировать", "");
КонецПроцедуры
№2 вариант с предупреждением за три дня
//*******************************************
// Процедура генерации запроса Сформировать.
//
Процедура Сформировать()
Перем Запрос, ТекстЗапроса, Таб;
//Создание объекта типа Запрос
Запрос = СоздатьОбъект("Запрос");
ТекстЗапроса =
"//{{ЗАПРОС(Сформировать)
|Наименование = Справочник.Сотрудники.Наименование;
|ДатаРождения = Справочник.Сотрудники.ФизЛицо.ДатаРождения;
|Группировка Наименование;
|"//}}ЗАПРОС
;
// Если ошибка в запросе, то выход из процедуры
Если Запрос.Выполнить(ТекстЗапроса) = 0 Тогда
Возврат;
КонецЕсли;
// Подготовка к заполнению выходных форм данными запроса
Таб = СоздатьОбъект("Таблица");
Таб.ИсходнаяТаблица("Сформировать");
// Заполнение полей "Заголовок"
Таб.ВывестиСекцию("Заголовок");
Состояние("Заполнение выходной таблицы...");
Таб.Опции(0, 0, Таб.ВысотаТаблицы(), 0);
Пока Запрос.Группировка(1) = 1 Цикл
Год = ДатаГод(Запрос.ДатаРождения);
Месяц = ДатаМесяц(Запрос.ДатаРождения);
День = ДатаЧисло(Запрос.ДатаРождения);
ТекГод = ДатаГод(РабочаяДата());
ТекМесяц = ДатаМесяц(РабочаяДата());
ТекДень = ДатаЧисло(РабочаяДата());
Если ((День < ТекДень) и (День > ТекДень - 4)и (Месяц = ТекМесяц) Тогда
Если ТекДень - День = 0 Тогда
Когда = "Сегодня!!!";
Иначе
КолВоДней = ТекДень - День;
Когда = "Через" + КолВоДней + "дн.";
КонецЕсли;
Возраст = ТекГод - Год;
// Заполнение полей Наименование
Таб.ВывестиСекцию("Наименование");
КонецЕсли
КонецЦикла;
// Вывод заполненной формы
Таб.ТолькоПросмотр(1);
Таб.Показать("Сформировать", "");
КонецПроцедуры