Индекс находится за границами массива 1с что это
Статьи
Ошибка «Индекс находится за пределами массива» в программах на платформе 1С Предприятие часто появляется при работе с базами данных, где имеются коллекции значений. Индекс в 1С Бухгалтерия применяется как счетчик элементов. Если в программе используются массивы, велика вероятность получения такого сообщения при выполнении кода. Рассмотрим, как он него избавиться в программах 1С 8.3.
Почему возникает ошибка
В большинстве случаев диалоговое окно с сообщением об ошибке появляется в программе 1С в том случае, если в коде идет обращение к элементу массива с использованием его индекса. Но при этом разработчик конкретного фрагмента кода не позаботился о том, чтобы проводилась проверка на его соответствие числу элементов. При выполнении какого-либо цикла возникнет ситуация, когда элементы закончатся, а программа 1С все равно будет обращаться к ним. Что и приведет к появлению сообщения.
Обнаружить ошибочный фрагмент кода легко, так как приложения на платформе 1С предприятие выводят строку кода, где оператор выполняется с ошибкой. При клике на кнопке «Подробно» в диалоговом окне программист получит нужную информацию.
Рассмотрим пример, в котором код создает массив с тремя значениями, а следующий за ним цикл имеет 10 итераций. При четвертом прохождении цикла возникнет ошибка «Индекс находится за пределами массива». Чтобы этого не допустить, необходимо либо изменить количество прохождений цикла либо добавлять условный оператор, который проверяет нахождение значений индекса в заданном диапазоне.
Обратите внимание, что в 1С Бухгалтерия и других программах на платформе 1С Предприятие индексы играют важную роль. Для получения значения индекса выделен специальный метод «Количество()». С его помощью можно работать со значениями в коллекции и получать значение конкретного элемента.
Учитывая это, следует соблюдать особую осторожность при работе с коллекциями в типовых конфигурациях. Так как внесение даже незначительных изменений неквалифицированными пользователями может привести к полной неработоспособности или серьезных ошибках в программе 1С и в учете.
Избежать этого помогут такие советы:
Заключение
Получить исчерпывающие консультации по программам 1С, получению обновлений 1С и настройке под нужны конкретного предприятия можно в компании «ГК в Приоритете». Свяжитесь с нашими сотрудниками и они помогут вам настроить программу с учетом индивидуальных потребностей и с гарантией ее работоспособности.
Индекс находится вне границ массива в 1С
Причины и способы устранения ошибки — индекс находится вне границ массива
Достаточно часто бухгалтерские, кадровые службы организаций могут сталкиваться с ситуациями, когда при выполнении необходимых для работы действий программа выдает сообщение о том, что индекс находится за границами массива 1С.
Закажите настройку БД 1С в IT RUSH!
Что значат, почему возникают такие ошибки?
Получение системного сообщения о том, что индекс элемента находится за границами массива или system indexoutofrangeexception, обозначает возникновение следующей ситуации:
Во время программирования были упущены некоторые моменты для проверки на количество коллекций в 1С. За все время использования продукта коллекции могут закончиться для выполнения важных этапов создания документов или отчетов. При этом 1С Предприятие будет делать попытки поиска, уведомит пользователя о выявленной проблеме таким оповещением.
Основными причинами подобных неполадок становятся такие процессы:
Попытки внести правки в конфигурацию СУБД самостоятельно могут привести к потере данных и рабочего состояния всех компонентов программы. Проверить все эти моменты, сделать необходимые настройки сможет программист нашей компании.
Обратитесь к специалистам
Исправить ошибку в программе 1С, когда индекс находился вне границ массива, своими силами бывает достаточно сложно, так как не все рядовые пользователи знают и понимают язык 1С.
Можно найти решение проблемы на различных форумах в интернете, но применить советы, указанные в сообщениях, не всегда возможно без профподготовки и грозит потерей всех данных.
Обращаться IT RUSH — это практичное и выгодное решение:
Стоимость работ специалиста IT-Rush программиста 1С по устранению ошибки “индекс находится за границами массива 1С”- от 1800 руб./час.
индекс находится за границами массива
У меня проблема: при формировании отчета выдает ошибку «индекс находится за границами массива»
Постоянно ругается,
вот кусок модуля:
// В процедуре можно доработать компоновщик перед выводом в отчет
// Изменения сохранены не будут
Процедура ДоработатьКомпоновщикПередВыводом(ВнешниеНаборыДанных) Экспорт
Если ЗначениеЗаполнено(Счет) Тогда
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «Счет», Счет);
КонецЕсли;
Если ЗначениеЗаполнено(НачалоПериода) Тогда
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «НачалоПериода», НачалоДня(НачалоПериода));
Иначе
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «НачалоПериода», Дата(1, 1, 1));
КонецЕсли;
Если ЗначениеЗаполнено(КонецПериода) Тогда
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «КонецПериода», КонецДня(КонецПериода));
Иначе
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «КонецПериода», Дата(3999, 11, 1));
КонецЕсли;
ТиповыеОтчеты.ДобавитьОтбор(КомпоновщикНастроек.Настройки.Структура[0].Структура[0].Отбор, «ПериодГруппировки»,,ВидСравненияКомпоновкиДанных.Заполнено);
ТиповыеОтчеты.ДобавитьОтбор(КомпоновщикНастроек.Настройки.Структура[0].Структура[0].Структура[0].Отбор, «Регистратор»,,ВидСравненияКомпоновкиДанных.Заполнено);
ТиповыеОтчеты.ДобавитьОтбор(КомпоновщикНастроек.Настройки.Структура[1].Структура[0].Отбор, «Регистратор»,,ВидСравненияКомпоновкиДанных.Заполнено);
ТиповыеОтчеты.УстановитьПараметрВывода(КомпоновщикНастроек.Настройки.Структура[0].Структура[0], «ВыводитьОтбор», ТипВыводаТекстаКомпоновкиДанных.НеВыводить);
ТиповыеОтчеты.УстановитьПараметрВывода(КомпоновщикНастроек.Настройки.Структура[0].Структура[0].Структура[0], «ВыводитьОтбор», ТипВыводаТекстаКомпоновкиДанных.НеВыводить);
ТиповыеОтчеты.УстановитьПараметрВывода(КомпоновщикНастроек.Настройки.Структура[1].Структура[0], «ВыводитьОтбор», ТипВыводаТекстаКомпоновкиДанных.НеВыводить);
Если Периодичность = 0 Тогда
КомпоновщикНастроек.Настройки.Структура[0].Использование = Ложь;
КомпоновщикНастроек.Настройки.Структура[1].Использование = Истина;
Иначе
КомпоновщикНастроек.Настройки.Структура[0].Использование = Истина;
КомпоновщикНастроек.Настройки.Структура[1].Использование = Ложь;
КонецЕсли;
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «Периодичность», Периодичность);
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «ПС», Символы.ПС);
Если ЗначениеЗаполнено(Подразделение) Тогда
ТиповыеОтчеты.ДобавитьОтбор(КомпоновщикНастроек, «Подразделение», Подразделение, ВидСравненияКомпоновкиДанных.ВИерархии);
КонецЕсли;
ЛинияСплошная = Новый Линия(ТипЛинииЯчейкиТабличногоДокумента.Сплошная, 1);
ТекущийНаборПоказателей = «» + ПоказателиОтчета.БУ.Значение + ПоказателиОтчета.НУ.Значение + ПоказателиОтчета.ПР.Значение + ПоказателиОтчета.ВР.Значение + ПоказателиОтчета.ВалютнаяСумма.Значение + ПоказателиОтчета.Количество.Значение;
МассивПоказателей = Новый Массив;
МассивПоказателей.Добавить(«БУ»);
МассивПоказателей.Добавить(«НУ»);
МассивПоказателей.Добавить(«ПР»);
МассивПоказателей.Добавить(«ВР»);
МассивПоказателей.Добавить(«ВалютнаяСумма»);
МассивПоказателей.Добавить(«Количество»);
Если ТекущийНаборПоказателей <> мТекущийНаборПоказателей Тогда
МассивМакетов = Новый Массив;
МассивМакетов.Добавить(«ПериодГруппировкиЗаголовок»);
МассивМакетов.Добавить(«ОбщиеИтогиЗаголовок»);
МассивМакетов.Добавить(«ОбщиеИтогиПодвал»);
МассивМакетов.Добавить(«ПроводкиЗаголовок»);
Для Каждого ЭлементМакет Из МассивМакетов Цикл
СхемаКомпоновкиДанных.Макеты[ЭлементМакет].Макет = СтандартныеОтчеты.ПолучитьКопиюОписанияМакета(СхемаКомпоновкиДанных.Макеты[ЭлементМакет + «Образец»].Макет);
ОписаниеМакета = СхемаКомпоновкиДанных.Макеты[ЭлементМакет].Макет;
МассивСтрокДляУдаления = Новый Массив;
Индекс = 0;
Для Каждого ЭлементМассива Из МассивПоказателей Цикл
Если Не ПоказателиОтчета[ЭлементМассива].Значение Тогда
МассивСтрокДляУдаления.Добавить(ОписаниеМакета[Индекс]);
КонецЕсли;
Индекс = Индекс + 1;
КонецЦикла;
Для Каждого Строка Из МассивСтрокДляУдаления Цикл
ОписаниеМакета.Удалить(Строка);
КонецЦикла;
Ошибки при работе в базе 1С
Ошибок в 1С может быть великое множество и происходить они могут по самым разным причинам.
Рассмотрим так называемые основные «виды» встречающихся ошибок.
Поле объекта не обнаружено
Ошибка возникает в ситуации, когда программа пытается обратится к реквизиту (полю) объекта которого просто не существует. Такая ситуация характерна для установки нового релиза, работающего на устаревшей платформе. В этом случае устаревшие механизмы платформы не учитывают изменений релиза и обращаются к атрибуту, которого уже не существует. Модуль, к которому идет обращение, перестает работать, но работу программа может не прерывать. Когда ошибка находится в модуле приложения или обработки, то при его запуске программа может и не запуститься. Таким образом, первый и основной вариант решения проблемы – это обновление платформы «1С:Предприятие».
В том случае, если возникновение ошибки не связано с платформой и настройками пользователя, то возможно произошел просто сбой в информационной базе, который повредил указанный объект. В таком случае рекомендуется провести «Тестирование и исправление информационной базы», в режиме Конфигуратор, в пункте меню «Администрирование».
Индекс находится за границами массива
Ошибка «индекс находится за границами массива» обозначает что программа обратилась к полю в массиве (таблице), которое еще не создано. Эта ошибка может возникать после внесения поправок в вашу конфигурацию, и это определенно ошибка программиста, внесшего правки.
Изредка она может возникать при переносе баз данных(БД) на другую версию 1С, но это тое говорит о том, что конфигурация правилась, но без учета особенностей 1С.
Облегчает исправление ошибки то, что вместе с ней программа указывает путь для конфигуратора к объекту, в котором возникла ошибка. Обратитесь к программисту для исправления данной ошибки.
Недостаточно памяти в 1С
Эта ошибка происходит в том случае, если у системы заканчивается вся оперативная память, выделенная под нужды выполнения программ в операционной системе. Она может произойти при различных событиях таких как обновление конфигурации, обработка большого файла, при формировании отчета, загрузки большой базы данных и т.д.
При чем добавление в устройство дополнительных планок оперативной памяти, проблему решает не всегда.
32-разрядные операционные системы имеют одну существенную особенность: независимо от объема оперативной памяти и размера файла подкачки, под работу конкретного приложения операционная система выделяет только 4 Гб. Учитывая, что половина адресного пространства виртуальной памяти выделяются под нужды самой системы, на работу приложения остается только 2Гб. При работе программы адресное пространство виртуальной памяти должно резервироваться одним непрерывным блоком. Когда нет такой возможности, выскакивает данная ошибка.
Без переустановки операционной системы существуют два варианта исправления ситуации:
Этими способами можно уменьшить адресное пространство, выделяемое под операционную систему до 1Гб, увеличив память под приложение до 3Гб.
Внимание! Вручную распределив память можно столкнуться с проблемами в работе персонального компьютера вплоть до полной остановки системы.
Удаление строки из файла boot.ini или запуск команды с заменой параметра 2900 на 2000 возвращает систему в исходное состояние.
Важно понимать, что указанные способы – только временное решение проблемы, для окончательного её устранения необходимо перенести базу на 64-разрядную платформу.
Не очень часто, но эта ошибка возникает при возникновении отчетов. В этом случае выполнение обработки формирования табличного документа затягивается и, в конце концов, заканчивается окном с данной ошибкой.
Прежде, чем лезть в настройки операционной системы и менять параметры распределения оперативной памяти, в этом случае лучше попробовать сменить настройки отчета. Поменяйте дату, измените группировки, добавьте отбор. В большинстве случаев это помогает.
индекс находится за границами массива
Перем СохраненнаяНастройка Экспорт;
Перем Расшифровки Экспорт;
Перем РежимРасшифровки Экспорт;
Перем СохранятьНастройкуОтчета Экспорт;
Функция ПолучитьПараметрыВыбораЗначенияОтбора() Экспорт
Процедура ОбработкаИзмененияСчета(ПолнаяОбработка = Истина) Экспорт
Если ЗначениеЗаполнено(Счет) Тогда
КоличествоСубконто = Счет.ВидыСубконто.Количество();
ИмяПоляПрефикс = «Субконто»;
Если ПолнаяОбработка Тогда
// Управление показателями
Если Счет.НалоговыйУчет Тогда
ДанныеОтчета.ПоказателиОтчета.БУ.Использование = Истина;
ДанныеОтчета.ПоказателиОтчета.БУ.Значение = Истина;
ДанныеОтчета.ПоказателиОтчета.НУ.Использование = Истина;
ДанныеОтчета.ПоказателиОтчета.НУ.Значение = Ложь;
ДанныеОтчета.ПоказателиОтчета.ПР.Использование = Истина;
ДанныеОтчета.ПоказателиОтчета.ПР.Значение = Ложь;
ДанныеОтчета.ПоказателиОтчета.ВР.Использование = Истина;
ДанныеОтчета.ПоказателиОтчета.ВР.Значение = Ложь;
Иначе
ДанныеОтчета.ПоказателиОтчета.БУ.Использование = Истина;
ДанныеОтчета.ПоказателиОтчета.БУ.Значение = Истина;
ДанныеОтчета.ПоказателиОтчета.НУ.Использование = Ложь;
ДанныеОтчета.ПоказателиОтчета.НУ.Значение = Ложь;
ДанныеОтчета.ПоказателиОтчета.ПР.Использование = Ложь;
ДанныеОтчета.ПоказателиОтчета.ПР.Значение = Ложь;
ДанныеОтчета.ПоказателиОтчета.ВР.Использование = Ложь;
ДанныеОтчета.ПоказателиОтчета.ВР.Значение = Ложь;
КонецЕсли;
Если Счет.Валютный Тогда
ДанныеОтчета.ПоказателиОтчета.ВалютнаяСумма.Использование = Истина;
ДанныеОтчета.ПоказателиОтчета.ВалютнаяСумма.Значение = Истина;
Иначе
ДанныеОтчета.ПоказателиОтчета.ВалютнаяСумма.Использование = Ложь;
ДанныеОтчета.ПоказателиОтчета.ВалютнаяСумма.Значение = Ложь;
КонецЕсли;
Если Счет.Количественный Тогда
ДанныеОтчета.ПоказателиОтчета.Количество.Использование = Истина;
ДанныеОтчета.ПоказателиОтчета.Количество.Значение = Истина;
Иначе
ДанныеОтчета.ПоказателиОтчета.Количество.Использование = Ложь;
ДанныеОтчета.ПоказателиОтчета.Количество.Значение = Ложь;
КонецЕсли;
Если Счет.УчетПоПодразделениям Тогда
НастройкиФормы.Вставить(«ДоступностьПодразделения», Истина);
Иначе
НастройкиФормы.Вставить(«ДоступностьПодразделения», Ложь);
КонецЕсли;
Если Не РежимРасшифровки Тогда
// Добавление неактивных отборов по субконто в соответствии с выбранным счетом
ОтборыДляУдаления = Новый Массив;
Для Каждого ЭлементОтбора Из КомпоновщикНастроек.Настройки.Отбор.Элементы Цикл
Если ТипЗнч(ЭлементОтбора) = Тип(«ЭлементОтбораКомпоновкиДанных») Тогда
Если Найти(ЭлементОтбора.ЛевоеЗначение, «Субконто») > 0 ИЛИ Строка(ЭлементОтбора.ЛевоеЗначение) = «Валюта»
ИЛИ (Найти(ЭлементОтбора.ЛевоеЗначение, «Подразделение») = 1 И НЕ Счет.УчетПоПодразделениям) Тогда
ОтборыДляУдаления.Добавить(ЭлементОтбора);
КонецЕсли;
КонецЕсли;
КонецЦикла;
Для Каждого ЭлементОтбора Из ОтборыДляУдаления Цикл
КомпоновщикНастроек.Настройки.Отбор.Элементы.Удалить(ЭлементОтбора);
КонецЦикла;
Если Не Счет.УчетПоПодразделениям Тогда
Подразделение = Неопределено;
КонецЕсли;
КонецЕсли;
КонецЕсли;
КонецЕсли;
Процедура ЗаполнитьНачальныеНастройки() Экспорт
Процедура СформироватьОтчет(Результат = Неопределено, ДанныеРасшифровки = Неопределено, ВыводВФормуОтчета = Истина, ВнешниеНаборыДанных = Неопределено, ВыводитьПолностью = Истина) Экспорт
Настройки = КомпоновщикНастроек.ПолучитьНастройки();
ВыводЗаголовкаОтчета(ЭтотОбъект, Результат);
Если ВыводитьПолностью Тогда
ДоработатьКомпоновщикПередВыводом(ВнешниеНаборыДанных);
КомпоновщикНастроек.Восстановить();
НастройкаКомпоновкиДанных = КомпоновщикНастроек.ПолучитьНастройки();
КомпоновщикНастроек.ЗагрузитьНастройки(Настройки);
СтандартныеОтчеты.ВывестиОтчет(ЭтотОбъект, Результат, ДанныеРасшифровки, ВыводВФормуОтчета, ВнешниеНаборыДанных, Истина, НастройкаКомпоновкиДанных);
КонецЕсли;
ВыводПодписейОтчета(ЭтотОбъект, Результат);
Если ВыводитьПолностью Тогда
// Выполним дополнительную обработку Результата отчета
ОбработкаРезультатаОтчета(Результат);
// Сохраним настройки для Истории
СтандартныеОтчеты.СохранитьНастройкуДляИстории(ЭтотОбъект);
КонецЕсли;
Процедура ПередВыводомОтчета(МакетКомпоновки) Экспорт
КоличествоПоказателей = 0;
Для Каждого Показатель Из ПоказателиОтчета Цикл
Если Показатель.Значение.Значение Тогда
КоличествоПоказателей = КоличествоПоказателей + 1;
КонецЕсли;
КонецЦикла;
// Если показатель один, то удалим столбик «Показатель»
Если КоличествоПоказателей = 1 Тогда
Для Каждого Макет Из МакетКомпоновки.Макеты Цикл
Для Каждого СтрокаМакета Из Макет.Макет Цикл
СтрокаМакета.Ячейки.Удалить(СтрокаМакета.Ячейки[4]);
КонецЦикла;
КонецЦикла;
КонецЕсли;
МакетПроводки = СтандартныеОтчеты.ПолучитьМакетГруппировкиПоПолюГруппировки(МакетКомпоновки, «Проводки», Истина);
Если МакетПроводки.Количество() = 1 Тогда
МакетПроводки = МакетПроводки[0];
ДанныеОтчета.Вставить(«МакетПроводок», МакетПроводки.Имя);
КонецЕсли;
Процедура ПередВыводомЭлементаРезультата(МакетКомпоновки, ДанныеРасшифровки, ЭлементРезультата, Отказ = Ложь) Экспорт
// В процедуре можно доработать компоновщик перед выводом в отчет
// Изменения сохранены не будут
Процедура ДоработатьКомпоновщикПередВыводом(ВнешниеНаборыДанных) Экспорт
Если ЗначениеЗаполнено(Счет) Тогда
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «Счет», Счет);
КонецЕсли;
Если ЗначениеЗаполнено(НачалоПериода) Тогда
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «НачалоПериода», НачалоДня(НачалоПериода));
Иначе
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «НачалоПериода», Дата(1, 1, 1));
КонецЕсли;
Если ЗначениеЗаполнено(КонецПериода) Тогда
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «КонецПериода», КонецДня(КонецПериода));
Иначе
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «КонецПериода», Дата(3999, 11, 1));
КонецЕсли;
//РУГАЕТСЯ НА ЭТУ СТРОЧКУ.
ТиповыеОтчеты.ДобавитьОтбор(КомпоновщикНастроек.Настройки.Структура[0].Структура[0].Структура[0].Отбор, «Регистратор»,,ВидСравненияКомпоновкиДанных.Заполнено);
//РУГАЕТСЯ НА ЭТУ СТРОЧКУ!
ТиповыеОтчеты.УстановитьПараметрВывода(КомпоновщикНастроек.Настройки.Структура[0].Структура[0], «ВыводитьОтбор», ТипВыводаТекстаКомпоновкиДанных.НеВыводить);
ТиповыеОтчеты.УстановитьПараметрВывода(КомпоновщикНастроек.Настройки.Структура[0].Структура[0].Структура[0], «ВыводитьОтбор», ТипВыводаТекстаКомпоновкиДанных.НеВыводить);
ТиповыеОтчеты.УстановитьПараметрВывода(КомпоновщикНастроек.Настройки.Структура[1].Структура[0], «ВыводитьОтбор», ТипВыводаТекстаКомпоновкиДанных.НеВыводить);
Если Периодичность = 0 Тогда
КомпоновщикНастроек.Настройки.Структура[0].Использование = Ложь;
КомпоновщикНастроек.Настройки.Структура[1].Использование = Истина;
Иначе
КомпоновщикНастроек.Настройки.Структура[0].Использование = Истина;
КомпоновщикНастроек.Настройки.Структура[1].Использование = Ложь;
КонецЕсли;
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «Периодичность», Периодичность);
ТиповыеОтчеты.УстановитьПараметр(КомпоновщикНастроек, «ПС», Символы.ПС);
Если ЗначениеЗаполнено(Подразделение) Тогда
ТиповыеОтчеты.ДобавитьОтбор(КомпоновщикНастроек, «Подразделение», Подразделение, ВидСравненияКомпоновкиДанных.ВИерархии);
КонецЕсли;
ЛинияСплошная = Новый Линия(ТипЛинииЯчейкиТабличногоДокумента.Сплошная, 1);
ТекущийНаборПоказателей = «» + ПоказателиОтчета.БУ.Значение + ПоказателиОтчета.НУ.Значение + ПоказателиОтчета.ПР.Значение + ПоказателиОтчета.ВР.Значение + ПоказателиОтчета.ВалютнаяСумма.Значение + ПоказателиОтчета.Количество.Значение;
МассивПоказателей = Новый Массив;
МассивПоказателей.Добавить(«БУ»);
МассивПоказателей.Добавить(«НУ»);
МассивПоказателей.Добавить(«ПР»);
МассивПоказателей.Добавить(«ВР»);
МассивПоказателей.Добавить(«ВалютнаяСумма»);
МассивПоказателей.Добавить(«Количество»);
Если ТекущийНаборПоказателей <> мТекущийНаборПоказателей Тогда
МассивМакетов = Новый Массив;
МассивМакетов.Добавить(«ПериодГруппировкиЗаголовок»);
МассивМакетов.Добавить(«ОбщиеИтогиЗаголовок»);
МассивМакетов.Добавить(«ОбщиеИтогиПодвал»);
МассивМакетов.Добавить(«ПроводкиЗаголовок»);
Для Каждого ЭлементМакет Из МассивМакетов Цикл
СхемаКомпоновкиДанных.Макеты[ЭлементМакет].Макет = СтандартныеОтчеты.ПолучитьКопиюОписанияМакета(СхемаКомпоновкиДанных.Макеты[ЭлементМакет + «Образец»].Макет);
ОписаниеМакета = СхемаКомпоновкиДанных.Макеты[ЭлементМакет].Макет;
МассивСтрокДляУдаления = Новый Массив;
Индекс = 0;
Для Каждого ЭлементМассива Из МассивПоказателей Цикл
Если Не ПоказателиОтчета[ЭлементМассива].Значение Тогда
МассивСтрокДляУдаления.Добавить(ОписаниеМакета[Индекс]);
КонецЕсли;
Индекс = Индекс + 1;
КонецЦикла;
Для Каждого Строка Из МассивСтрокДляУдаления Цикл
ОписаниеМакета.Удалить(Строка);
КонецЦикла;
Процедура ВыводЗаголовкаОтчета(ОтчетОбъект, Результат)
Процедура ВыводПодписейОтчета(ОтчетОбъект, Результат)
Функция ПолучитьТекстЗаголовка(ОрганизацияВНачале = Истина) Экспорт
ЗаголовокОтчета = «Карточка счета » + Счет + СтандартныеОтчеты.ПолучитьПредставлениеПериода(ЭтотОбъект);
Процедура ПолучитьСтруктуруПоказателейОтчета() Экспорт
ПоказателиОтчета = СтандартныеОтчеты.ПолучитьСтруктуруПоказателейОтчета(. Ложь, Истина, Истина, Ложь);
ДанныеОтчета.Вставить(«ПоказателиОтчета», ПоказателиОтчета);
// Зафиксируем заголовок отчета
ВысотаЗаголовка = Результат.Области.Заголовок.Низ;
Результат.ФиксацияСверху = ВысотаЗаголовка + 2;
// Для настройки отчета (расшифровка и др.)
Процедура Настроить() Экспорт
Процедура СохранитьНастройку() Экспорт
Если СохранятьНастройкуОтчета Тогда
СтандартныеОтчеты.СохранитьНастройку(ЭтотОбъект);
КонецЕсли;
// Процедура заполняет параметры отчета по элементу справочника из переменной СохраненнаяНастройка.
Процедура ПрименитьНастройку() Экспорт
Если СохраненнаяНастройка.Пустая() Тогда
Возврат;
КонецЕсли;
СтруктураПараметров = СохраненнаяНастройка.ХранилищеНастроек.Получить();
Если РежимРасшифровки Тогда
НастройкиФормы = СтруктураПараметров.НастройкиФормы;
Иначе
ТиповыеОтчеты.ПрименитьСтруктуруПараметровОтчета(ЭтотОбъект, СтруктураПараметров);
КонецЕсли;