N
nestovby
Вновь возвращаюсь к моей проблеме с обьединением нескольких справочников (3-ех). С запросами не получилось решить проблему https://codeby.net/threads/45776.html
По советам сделал через Таблицу Значений, но результат точно такой же - не получается вывести все в одной строке.
вот картинка:
Нужно чтобы выделенные ставки выводились напротив свох Степеней и Званий, а они выводятся отдельно.
Вроде бы правильно написал "Свернуть", но видимо как-то ошибка в структуре вывода справочников. Не могу никак понять в чем ошибка.
Подскажите, пожалуйста, как мне решить мою ошибку и в чем я не прав.
Я вывожу сначала главный справочник, потом по отдельности два других - но видимо это не правильно, так где же мне их вывести?.
вот мой код:
По советам сделал через Таблицу Значений, но результат точно такой же - не получается вывести все в одной строке.
вот картинка:

Нужно чтобы выделенные ставки выводились напротив свох Степеней и Званий, а они выводятся отдельно.
Вроде бы правильно написал "Свернуть", но видимо как-то ошибка в структуре вывода справочников. Не могу никак понять в чем ошибка.
Подскажите, пожалуйста, как мне решить мою ошибку и в чем я не прав.
Я вывожу сначала главный справочник, потом по отдельности два других - но видимо это не правильно, так где же мне их вывести?.
вот мой код:
Код:
Процедура Сформировать()
перем пд, ИтогоЗаСтепень, ИтогоЗаЗвание;
Таб=СоздатьОбъект("ТаблицаЗначений");
Если Подр=1 Тогда
Таб.НоваяКолонка("Подразделение","Справочник.Подразделения");
КонецЕсли;
СпрСотр=СоздатьОбъект("Справочник.Сотрудники");
ПрикДл=СоздатьОбъект("Справочник.ПриказыДлительногоДействия");
КадрДанные=СоздатьОбъект("Справочник.КадровыеДанные");
ДопУчСт= СоздатьОбъект("Справочник.ДоплатыЗаУченуюСтепень");
ДопУчЗв= СоздатьОбъект("Справочник.ДоплатыЗаУченыеЗвания");
Таб.НоваяКолонка("Степень2","перечисление.УченаяСтепень");
Таб.НоваяКолонка("Степень","перечисление.УченаяСтепень");
Таб.НоваяКолонка("Ставка","Число",4,2);
Таб.НоваяКолонка("ЧислоСтавокНеППС","Число",4,2);
Таб.НоваяКолонка("ЧислоСтавокДляППС","Число",4,2);
Таб.НоваяКолонка("Звание","Перечисление.УченоеЗвание");
Таб.НоваяКолонка("Звание2","Перечисление.УченоеЗвание");
Таб.НоваяКолонка("Совместитель","Справочник.ВнутренниеСовместители");
СпрСотр.ИспользоватьДату(ДатаОт);
СпрСотр.ПорядокНаименований();
СпрСотр.ВыбратьЭлементы();
Пока СпрСотр.ПолучитьЭлемент()=1 Цикл
Если СпрСотр.ЭтоГруппа() = 1 Тогда
Продолжить;
КонецЕсли;
Если СпрСотр.Родитель = СпрУволенные Тогда
Продолжить;
КонецЕсли;
Если (СпрСотр.ВидРаботника=Перечисление.ВидыРаботников.ТрудовойДоговор) Тогда
Продолжить;
КонецЕсли;
ПрикДл.ИспользоватьВладельца(СпрСотр.ТекущийЭлемент());
ПрикДл.ВыбратьЭлементы();
Пока ПрикДл.ПолучитьЭлемент()=1 Цикл
пр=0;
Если (ПрикДл.Приказ.Вид()="ПостоянныеНачисленияУдержания") и (ПрикДЛ.Приказ.ВидРасч=ВидРасчета.ПрочиеНачисления) Тогда
Если (ПрикДл.Приказ.Вид.Код="4") или (ПрикДл.Приказ.Вид.Код="5") Тогда
пр=1;
КонецЕсли;
Если пр=1 Тогда
Сообщить(СпрСотр.Наименование);
КадрДанные.ИспользоватьВладельца(СпрСотр.ТекущийЭлемент());
КадрДанные.ВыбратьЭлементы();
пока кадрДанные.ПолучитьЭлемент()=1 цикл
Таб.НоваяСтрока();
Таб.Степень=КадрДанные.УченаяСтепень.ученаястепень;
Таб.Звание=КадрДанные.УченоеЗвание;
// Таб.Зв=?(ПустоеЗначение(КадрДанные.УченоеЗвание)=1,ДопУчЗв.УченоеЗвание,КадрДанные.УченоеЗвание);
Таб.Ставка=?(ПустоеЗначение(ПрикДл.Приказ.ВнСовместитель)=1,СпрСотр.Ставка,ПрикДл.Приказ.ВнСовместитель.Ставка.Получить(ДатаОт));
Таб.Совместитель=ПрикДл.Приказ.ВнСовместитель;
конеццикла;
КонецЕсли;
КонецЕсли;
КонецЦикла;
КонецЦикла;
// ПЕРВЫЙ СПРАВОЧНИК Я ВЫВЕЛ ПРАВИЛЬНО, ТЕПЕРЬ ВЫВОЖУ ДВА ДРУГИХ. МОЖЕТ БЫТЬ ИХ НУЖНО ГДЕ-ТО В ДРУГОМ МЕСТЕ ВЫВЕСТИ, ЧТОБЫ СОЕДИНИТЬ ОДИНАКОВЫЕ ПОЛЯ?
ДопУчЗв.выбратьэлементы();
пока ДопУчЗв.получитьЭлемент()=1 цикл
Таб.НоваяСтрока();
Таб.Звание2=ДопУчЗв.УченоеЗвание;
Таб.ЧислоСтавокДляППС=ДопУчЗв.ЧислоСтавокДляППС.Получить(ДатаОт);
конеццикла;
ДопУчСт.выбратьэлементы();
пока ДопУчСт.получитьэлемент()=1 цикл
Таб.НоваяСтрока();
Таб.Степень2=ДопУчСт.УченаяСтепень;
Таб.ЧислоСтавокНеППС=ДопУчСт.ЧислоСтавокНеППС;
конеццикла;
Таб.Свернуть("Степень,звание,Степень2,Звание2,Совместитель,ЧислоСтавокНеППС,ЧислоСтавокДля
ППС","Ставка");
ТабД=СоздатьОбъект("Таблица");
ТабД.ВывестиСекцию("Заголовок");
ТабД.ПовторятьПриПечатиСтроки(3,3);
ТабД.ВывестиСекцию("Шапка");
Если Подр=1 Тогда
Таб.Сортировать("Ставка");
Иначе
Таб.Сортировать("Ставка");
КонецЕсли;
Таб.ВыбратьСтроки();
Пока Таб.ПолучитьСтроку()=1 Цикл
ТабД.ВывестиСекцию("Строка");
КонецЦикла;
КС=ТабД.КоличествоСтраниц();
ТабД.ВывестиСекцию("Итого");
ТабД.Показать("Доплаты за степень и звание");
КонецПроцедуры
ДатаОт=ТекущаяДата();
СтрОрг=Перечисление.СтруктураОрганизации.ОсновнойСостав;
Подр=1;