Флавия
Автор
400646
Просмотров
3.142.69.168
Ваш IP
21 сентября 2023
Дата создания

Обработка с инфостартра

Имя обработки:
 
Тип обработки:
1C: Предприятие 8.2
Категория:Все для 1C:8, Не имеет значения
Конфигурация:Практика программирования
Кому предназначена обработкаАдминистратор, Программист
Краткое описаниеПРИМЕР БЕЗ ПРОГРАММИРОВАНИЯ

Для начала давайте рассмотрим способ вывода отчета из вложенной схемы без программирования. У нас есть два отчета:

Остатки товаров;
Цены номенклатуры;

На основании двух отчетов необходимо составить один отчет, где отчет «Цены номенклатуры» будут вызываться как вариант отчета «Остатки товаров» (пример не совсем по смыслу, но демонстрирует возможности платформы).
Итак, сначала откроем отчет «Цены номенклатуры» в конфигураторе и сохраним схему отчета в файл.

Теперь перейдем в отчет «Остатки номенклатуры», откроем основную схему компоновки данных на вкладке «Вложенные схемы». После добавления новой вложенной схемы, загрузим сохраненную схему. Хочу обратить внимание на то, что нельзя изменять имя и заголовок отчета.

Создадим новый вариант отчета, дадим ему имя «Цены номенклатуры», подключим вложенный отчет. Должно выйти примерно так, как на картинке.

Запустим отчет в режиме «1С Предприятия» и убедимся, что нам доступны 2 варианта отчета.

ПРОГРАММНЫЙ ВЫВОД ОТЧЕТА С ВЛОЖЕННЫМИ СХЕМАМИ

Хорошо, теперь заделаем то же, но для программного вывода отчета. Задача та же, но отчет будем формировать программно. Такая ситуация может возникнуть например при вызове отчета из обработки.

Следующий код выводит отчет из макета обработки:

&НаКлиенте
Процедура ОстаткиНоменклатуры(Команда)
СформироватьОтчетОстаткиНоменклатуры();
КонецПроцедуры

&НаСервере
Процедура СформироватьОтчетОстаткиНоменклатуры()
ОбработкаОбъект = РеквизитФормыВЗначение("Объект");
СхемаКомпоновкиДанных = ОбработкаОбъект.ПолучитьМакет("Макет");
ЗначениеВРеквизитФормы(ОбработкаОбъект, "Объект");

Настройки = СхемаКомпоновкиДанных.НастройкиПоУмолчанию;

КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных;
ДанныеРасшифровкиКД = Новый ДанныеРасшифровкиКомпоновкиДанных;
МакетКомпоновки = КомпоновщикМакета.Выполнить(СхемаКомпоновкиДанных, Настройки);

ПроцессорКомпоновкиДанны = Новый ПроцессорКомпоновкиДанных;
ПроцессорКомпоновкиДанны.Инициализировать(МакетКомпоновки);

ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВТабличныйДокумент;

ПроцессорВывода.УстановитьДокумент(Результат);
ПроцессорВывода.Вывести(ПроцессорКомпоновкиДанны);
КонецПроцедуры


Перейдем к выводу вложенной схемы. Давайте посмотрим отладчиком, где ее искать.

Вот она, во вложенных схемах компоновки данных. Дело за малым, осталось программно вывести результат работы процессора компоновки в форму.

&НаКлиенте
Процедура ЦеныНоменклатуры(Команда)
СформироватьОтчетЦеныНоменклатуры();
КонецПроцедуры

&НаСервере
Процедура СформироватьОтчетЦеныНоменклатуры()
ОбработкаОбъект = РеквизитФормыВЗначение("Объект");
СхемаКомпоновкиДанных = ОбработкаОбъект.ПолучитьМакет("Макет");
ЗначениеВРеквизитФормы(ОбработкаОбъект, "Объект");

ВложеннаяСКД = СхемаКомпоновкиДанных.ВложенныеСхемыКомпоновкиДанных.Найти("Отчет1");

Если ВложеннаяСКД = Неопределено Тогда
ВызватьИсключение НСтр("ru=""Не удалось получить вложенную схему компоновки данных.""");
Возврат;
КонецЕсли;

Настройки = ВложеннаяСКД.Схема.НастройкиПоУмолчанию;

КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных;
ДанныеРасшифровкиКД = Новый ДанныеРасшифровкиКомпоновкиДанных;
МакетКомпоновки = КомпоновщикМакета.Выполнить(ВложеннаяСКД.Схема, Настройки);

ПроцессорКомпоновкиДанны = Новый ПроцессорКомпоновкиДанных;
ПроцессорКомпоновкиДанны.Инициализировать(МакетКомпоновки);

ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВТабличныйДокумент;

ПроцессорВывода.УстановитьДокумент(Результат);
ПроцессорВывода.Вывести(ПроцессорКомпоновкиДанны);
КонецПроцедуры



В заключение скажу, вложенные схемы – прекрасный механизм, который позволяет гибко использовать функционал схемы компоновки данных.

Статья написана по материалам сайта avtomat.biz



Ссылка на обработку:infostart.ru/public/173309
Скачать программу:/Download/report/173309.rar
Комментария к обработке:


ПРИМЕР БЕЗ ПРОГРАММИРОВАНИЯ

Для начала давайте рассмотрим способ вывода отчета из вложенной схемы без программирования. У нас есть два отчета:

Остатки товаров;
Цены номенклатуры;

На основании двух отчетов необходимо составить один отчет, где отчет «Цены номенклатуры» будут вызываться как вариант отчета «Остатки товаров» (пример не совсем по смыслу, но демонстрирует возможности платформы).
Итак, сначала откроем отчет «Цены номенклатуры» в конфигураторе и сохраним схему отчета в файл.

Теперь перейдем в отчет «Остатки номенклатуры», откроем основную схему компоновки данных на вкладке «Вложенные схемы». После добавления новой вложенной схемы, загрузим сохраненную схему. Хочу обратить внимание на то, что нельзя изменять имя и заголовок отчета.

Создадим новый вариант отчета, дадим ему имя «Цены номенклатуры», подключим вложенный отчет. Должно выйти примерно так, как на картинке.

Запустим отчет в режиме «1С Предприятия» и убедимся, что нам доступны 2 варианта отчета.

ПРОГРАММНЫЙ ВЫВОД ОТЧЕТА С ВЛОЖЕННЫМИ СХЕМАМИ

Хорошо, теперь заделаем то же, но для программного вывода отчета. Задача та же, но отчет будем формировать программно. Такая ситуация может возникнуть например при вызове отчета из обработки.

Следующий код выводит отчет из макета обработки:

&НаКлиенте
Процедура ОстаткиНоменклатуры(Команда)
СформироватьОтчетОстаткиНоменклатуры();
КонецПроцедуры

&НаСервере
Процедура СформироватьОтчетОстаткиНоменклатуры()
ОбработкаОбъект = РеквизитФормыВЗначение("Объект");
СхемаКомпоновкиДанных = ОбработкаОбъект.ПолучитьМакет("Макет");
ЗначениеВРеквизитФормы(ОбработкаОбъект, "Объект");

Настройки = СхемаКомпоновкиДанных.НастройкиПоУмолчанию;

КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных;
ДанныеРасшифровкиКД = Новый ДанныеРасшифровкиКомпоновкиДанных;
МакетКомпоновки = КомпоновщикМакета.Выполнить(СхемаКомпоновкиДанных, Настройки);

ПроцессорКомпоновкиДанны = Новый ПроцессорКомпоновкиДанных;
ПроцессорКомпоновкиДанны.Инициализировать(МакетКомпоновки);

ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВТабличныйДокумент;

ПроцессорВывода.УстановитьДокумент(Результат);
ПроцессорВывода.Вывести(ПроцессорКомпоновкиДанны);
КонецПроцедуры


Перейдем к выводу вложенной схемы. Давайте посмотрим отладчиком, где ее искать.

Вот она, во вложенных схемах компоновки данных. Дело за малым, осталось программно вывести результат работы процессора компоновки в форму.

&НаКлиенте
Процедура ЦеныНоменклатуры(Команда)
СформироватьОтчетЦеныНоменклатуры();
КонецПроцедуры

&НаСервере
Процедура СформироватьОтчетЦеныНоменклатуры()
ОбработкаОбъект = РеквизитФормыВЗначение("Объект");
СхемаКомпоновкиДанных = ОбработкаОбъект.ПолучитьМакет("Макет");
ЗначениеВРеквизитФормы(ОбработкаОбъект, "Объект");

ВложеннаяСКД = СхемаКомпоновкиДанных.ВложенныеСхемыКомпоновкиДанных.Найти("Отчет1");

Если ВложеннаяСКД = Неопределено Тогда
ВызватьИсключение НСтр("ru=""Не удалось получить вложенную схему компоновки данных.""");
Возврат;
КонецЕсли;

Настройки = ВложеннаяСКД.Схема.НастройкиПоУмолчанию;

КомпоновщикМакета = Новый КомпоновщикМакетаКомпоновкиДанных;
ДанныеРасшифровкиКД = Новый ДанныеРасшифровкиКомпоновкиДанных;
МакетКомпоновки = КомпоновщикМакета.Выполнить(ВложеннаяСКД.Схема, Настройки);

ПроцессорКомпоновкиДанны = Новый ПроцессорКомпоновкиДанных;
ПроцессорКомпоновкиДанны.Инициализировать(МакетКомпоновки);

ПроцессорВывода = Новый ПроцессорВыводаРезультатаКомпоновкиДанныхВТабличныйДокумент;

ПроцессорВывода.УстановитьДокумент(Результат);
ПроцессорВывода.Вывести(ПроцессорКомпоновкиДанны);
КонецПроцедуры



В заключение скажу, вложенные схемы – прекрасный механизм, который позволяет гибко использовать функционал схемы компоновки данных.

Статья написана по материалам сайта avtomat.biz
1. GreenFox 13.02.13 00:41
Идея конечно хороша, но если посмотреть в типовую конфигурацию то там есть справочник который называется "Дополнительные внешние обработки" - он иерархический - группируйте по смыслу сколько хотите даже переделывать не прийдется ни одного отчета. И отчеты остануться проще в сопровождении. Я например когда б пришел на проект и мне поставили задачу что-нибудь изменить в таком громоздком отчете пришел бы вначале в ужас. Не понимаю зачем все так усложнять?
+1 – Ответить 5
2. akomar 451 13.02.13 00:58
(1) Здравствуйте, спасибо за отзыв. Мне конечно известно о иерархичности справочника «Внешние обработки и отчеты». Но увы, пользователи клиента хотели, чтобы, например, несколько разработанных доп. отчетов были по рукой и чтобы их запустить без переключатся между окнами (у менеджеров очень мало времени :)). Вот и пришлось идти на извращения разного рода. Кто платит тот и прав, главное чтобы клиент был доволен.
+ – Ответить
3. Ibrogim 1295 13.02.13 07:26
(2) Раз уж пишите статью про вложенные схемы, то неплохо было бы раскрыть тему передачи параметров в них ( том числе и программное).
+3 – Ответить
8. akomar 451 13.02.13 12:43
(3) Наверно это будет тема следующей статьи.
+ – Ответить
4. vec435 15 13.02.13 08:32
(2) в таком случае создать доп форму избранное и пусть добавляют ссылки в нее на любые отчеты
+4 – Ответить
9. akomar 451 13.02.13 12:43
(4)Хорошая идея, учту.
+ – Ответить
5. zqzq 23 13.02.13 08:53
Автор извратился и решил задачу, которая:
1) по-нормальному решается 2-мя независимыми источниками данных и 2-мя вариантами, вложенные схемы не для того предназначены (а для формирования отчета с вложенными подотчетами (с) кэп)
2) задача надуманная (как писали выше) и рождённая от буквального понимания безумных хотелок пользователей (ну да... некогда думать, прыгать (грести деньги) надо).

PS Может погорячился... Впринципе достаточно малотрудозатратный способ продемонстрирован, хотя и не совсем "правильный".
+4 – Ответить 1
10. akomar 451 13.02.13 12:44
(5)Спасибо за критику. Способ не совсем правильный, но зато работает :)
+ – Ответить
6. yuraos 988 13.02.13 10:30

Теперь перейдем в отчет «Остатки номенклатуры», откроем основную схему компоновки данных на вкладке «Вложенные схемы». После добавления новой вложенной схемы, загрузим сохраненную схему. Хочу обратить внимание на то, что нельзя изменять имя и заголовок отчета.


А почему собственно нельзя менять, можно по-подробнее ?
Чтобы не менять их в примере кода ниже по тексту статьи ???
+ – Ответить 3
7. akomar 451 13.02.13 12:42
(6)Нельзя менять - потому что не сможете добавить вложенную схему в вариант отчета (по моему инфа есть в бесплатных уроках по СКД на сайте spec8.ru)
+1 – Ответить
13. yuraos 988 13.02.13 14:46
(7)
СКД также неисчерпаема, как 1С.
а 1С также неисчепаема, как электрон.
а электрон также неисчерпаем, как атом.
---
Нуралиев - верный марксист-ленинец,
творчески развивает идеи классиков!
:)
+3 – Ответить
16. StepanZaytsev 03.10.13 14:27
(7)название можно менять
+1 – Ответить
11. Новенький_2209 13.02.13 13:46
Хорошая статья. Очень бы хотелось посмотреть как в шаблоне типового отчета (который на обычных формах) можно:
1. разрешить использование вложенных схем
2. заставить работать интерфейсные элементы, с этими вложенными схемами.

П.1 я победил. По п.2 - копал глубоко, но расковырять так и не смог. Если бы автор как то просветил этот момент - цветы к его прижизненному памятнику обещаю носить ежегодно :)
+ – Ответить 2
18. trumanl 12 18.11.14 11:27
(11) Новенький_2209, Вы не подскажите как вы "победили" в шаблоне типового отчета использование вложенных схем ??
+ – Ответить
19. akomar 451 18.11.14 11:52
(18) Хм, как нибуть конкретизируйте вопрос :)
+ – Ответить
12. vec435 15 13.02.13 14:05
панель избранное
http://infostart.ru/public/78599/
http://infostart.ru/public/15324/
http://infostart.ru/public/19381/
+ – Ответить
14. DoctorRoza 13.02.13 19:08
Неплохо, может и пригодится!
+ – Ответить
15. masik85 21 14.02.13 08:55
спасибо за статью, у нас такие же пользователи-извращенцы соответственно и программистам приходится извращаться, как я вас понимаю
+ – Ответить
17. Ele1234567 21.05.14 12:47
Подскажите а как в таком варианте реализации отчета программно установить параметры для вложенной схемы?
+ – Ответить 1
22. 20tanush 30.03.16 10:40
(17) Ele1234567, попробую помочь:

ПараметрыВложСхемы = КомпоновщикНастроек.Настройки.Структура[1].Настройки.ПараметрыДанных.Элементы; // индекс в структуре у вас может быть другой, посмотрите в отладчике
ВложПараметр = ПараметрыВложСхемы.Найти("ИмяВашегоПараметра");
ВложПараметр.Использование = Истина;
ВложПараметр.Значение = ЗначениеВашегоПараметра;



У меня это работает. Спасибо вот этой статье: http://www.forum.mista.ru/topic.php?id=492695
+ – Ответить
20. Kuklachel 10.06.15 17:22
Добрый день. Я все делаю как у вас указано, Создаю схему отчета во вложенных схемах, загружаю туда xml, на вкладке "настройки" добавляю вариант отчета и добавляю в него вложенный отчет. В режиме предприятия видны два варианта, но формируется только основной. Подскажите, пожалуйста, почему так?
+ – Ответить 1
21. user_2010 871 22.03.16 11:52
(20) Kuklachel, так и должно быть: формируя отчет - вы выбираете вариант, который хотите сформировать. Ваш вариант содержит только один отчет - он и формируется.
Автор реализовал возможность открыв один отчет - выбирать разные варианты отчета и формировать их.
А вам нужно, видимо, в одном отчете сформировать два разных отчета. Тоже сейчас над этим думаю...
+ – Ответить
23. quares 21 23.11.17 13:23
Спасибо, пригодилось!
Изначально изобретал велосипед и создавал две отдельные схемы с мудрёным переключением между ними.
+ – Ответить