Как добавить использование групп в справочнике 1c.

Знакомство с 1С Бухгалтерией

В программе 1С Бухгалтерия справочники служат для хранения условно-постоянной информации, поддержки внутрифирменных или общих классификаторов. Так-же справочники используются для формирования списков возможного значения субконто т.е. для организации аналитического учета. Использованние справочников позволяет исключить неоднозначность при использовании реквизитов документов или иных справочников. Например, если в счете требуется вводить название организации клиента, выбор элемента из справочника клиента позволит избежать ввода ошибочного наименования разными конечными пользователями. Работа со справочниками может осуществляться в двух режимах: режим Просмотра и редактирования и режим Выбора элемента справочника .

Вызов справочника

Форму справочника можно вызвать через главное меню программы нажав кнопку в панели инструментов или в гланом меню программы Операции > Справочники .

На экран будет выдан список существующих в системе справочников. В этом списке клавишами или мышью следует выбрать наименование справочника и затем нажать кнопку ОК .

Окно с выбранным справочником будет выдано на экран. В заголовке окна выдается название справочника.

Если справочник является подчиненным какому либо другому справочнику то в заголовке окна справочника выдается в скобках наименование элемента или справочника родителя.

Окно справочника представляет собой в общем случае таблицу, набор граф в которой полностью определяется конфигурацией. Обычно присутствует две графы: Код и Наименование элемента справочника

Просмотр реквизитов справочника

Для просмотра реквизитов справочника необходимо установить курсор в строку с нужным элементом и нажать клавишу Enter . На экран будет выдан диалог для редактирования элементов справочника. Для закрытия диалога можно нажать клавишу Esc .

Активная ячейка

Одна ячейка всегда выделена инверсным цветом и называется активной или текущей. Так же называется строка или столбец на пересечении которых находится ячейка.

Просмотр справочника

Для просмотра справочника используются общие приемы работы с табличной частью формы. Заголовок группы позволяет перейти к элементам входящим в группу. Раскрыть группу в справочнике можно дважды щелкнув мышью на значке в строке с наименованием нужной группы.

В результате будет открыта выбранная группа. Название этой группы и всех групп верхнего уровня будет выдано в первых строках таблицы.

Просмотр дерева групп

Дерево групп содержит наименование групп справочника позволяет во первых удобно просматривать структуру справочника и во вторых быстро переходить к элементам входящим в конкретную группу справочника. Наименование справочника служит корневым элементом дерева групп.

Справочники 1С — специализированный объект древа метаданных, который служит для хранения статичной информации справочного характера. Например, в типовых конфигурациях можно увидеть следующие виды: , Номенклатура, Сотрудники, Основные средства и т.д. Информация в справочниках, как правило, часто не изменяется. Справочники в дальнейшем используются практически во всех объектах учета как разрез учета или справочная информация.

Ниже мы рассмотрим настройку и проектирование справочника из конфигуратора на примере справочника «Номенклатура».

Вкладка «Основные»

На вкладке «Основные» указывается имя, синоним, представление объектов, описание назначения.

Вкладка «Иерархия справочника»

Здесь устанавливается иерархичность справочника.

Иерархия в 1С 8.3 бывает двух типов — «групп и элементов » и «элементов «. Отличается тем, что в первом случае родителем (папкой) может быть только папка (группа), а во втором случае родителем может быть и элемент.

«Размещать группы сверху» — флаг отвечает за отображение групп в форме списка.

Также в настройках можно ограничить количество групп иерархии справочника соответствующей настройкой.

Вкладка «Владельцы»

Справочник может быть подчинен другому справочнику. С точки зрения конфигурирования 1С 8.3 это значит, что у подчиненного элемента становится обязательным реквизит «Владелец». Пример такой связи справочников в типовых конфигурациях «Номенклатура — Единицы Измерения», «Контрагенты-Договоры Контрагентов».

Владельцем справочника могут также быть следующие объекты метаданных: , .

Вкладка «Данные»

Получите 267 видеоуроков по 1С бесплатно:

Самая важная вкладка с точки зрения программиста. На ней указываются реквизиты справочника.

У справочника есть набор стандартных реквизитов, которые не редактируются программистом 1С 8.2, список их можно увидеть, нажав кнопку «Стандартные реквизиты»:

Остановлюсь на каждом подробнее:

  • ЭтоГруппа — реквизит с типом булево, показывающий, группа это или элемент. Доступен только в иерархическом справочнике. Обратите внимание, значение этого реквизита невозможно изменить в режиме 1С: Предприятие .
  • Код — реквизит, тип число или строка (как правило строка). Номер, присваиваемый системой автоматически. Как правило, рассчитывается как (предыдущий код + 1). Рекомендую использовать именно строковый тип, потому как сортировка числовых значений происходит не так, как нужно. Можно использовать как представление справочника в списке и в полях ввода. Как правило, используется для поиска элемента при вводе по строке. Если Вам нужно убрать поле Код, укажите в длине строки ноль.
  • Наименование — реквизит, обязательный к заполнению, строкового типа. Максимальная длина строки — 150 символов. Можно использовать как представление справочника в списке и в полях ввода. Как правило, используется для поиска элемента при вводе по строке. Если Вам нужно убрать поле Наименование, укажите в длине строки ноль.
  • Родитель — реквизит, имеющий тип СправочникСсылка.<ИмяТекущегоСправочника>. Доступен только в иерархическом справочнике. Указывает на вышестоящего родителя в иерархии. Если Элемент или Группа находятся в корне справочника, указывается значение Справочник.<ИмяТекущегоСправочника>.ПустаяСсылка.
  • Владелец — ссылка на элемент-владелец текущего элемента (группы) справочника. Доступен только в подчиненном справочнике 1С .
  • ПометкаУдаления — реквизит с типом булево. Отвечает за отображение «пометки удаления» в системе. Помеченный на удаление элемент считается непригодным к использованию, однако на нём могут оставаться старые движения в документах.
  • Ссылка — поле строкового типа. В этом реквизите хранится уникальный идентификатор объекта — GUID. То, что в системе мы видим в визуальном отображении под название «ссылка», — это всего лишь представление объекта. Невозможно изменить.
  • Предопределенный — тип булево, отображает, является ли элемент предопределенным, об этом позже. Невозможно изменить.

На вкладке «Данные» так же указывается представление справочника в системе, до версии 8.2.16 представление могло быть лишь Кодом или Наименованием. В свежих версиях платформы (начиная с 8.3) представление можно описать самостоятельно в модуле менеджера с помощью обработчика «ОбработкаПолученияПредставления».

Вкладка «Нумерация»

Здесь указываются настройки справочника по части нумерации. Рекомендуется использовать именно автонумерацию. Контроль уникальности — флаг, который помогает, если нужно, сделать код уникальным. Если с установленным флагом Вы попытаетесь записать элемент справочника с неуникальным кодом, в 1С Вы получите сообщение «Код справочника стал неуникальным».

Серия кодов — определяет, как нумеровать справочник, можно ввести нумерацию справочника в разрезе владельца. Например, у контрагента «Рога и копыта» будет иметься своя нумерация договоров — «1, 2, 3» и тд.

Вкладка «Формы»

Тут описываются формы для справочника. Если конфигурация запускается как в обычном, так и управляемом режиме, тогда вкладок с формами по умолчанию будет две: «основные» и «дополнительные» — для обычного и управляемого приложения разные.

На этой странице есть немаловажное свойство справочника — ««. Это очень удобная функция 1С 8, позволяющая при заполнении данных в поле ввода не заходить в справочник, а набрать его наименование, код или т.п. и выбрать из выпадающего списка нужный элемент. Выглядит это так:

Вкладка «Прочее»

На вкладке можно получить быстрый доступ к основным модулям справочника — модулю объекта и модулю менеджера.

На странице можно также определить список предопределенных элементов справочника. Это элементы, которые невозможно удалить в режиме Предприятия. К предопределенным элементам можно обратиться в конфигураторе напрямую, по имени, например: Справочники.Номенклатура.Услуга.

На этой вкладке также определяется режим блокировки — автоматический или управляемый. Использование полнотекстового поиска, а также справочная информация о справочнике, доступная в режиме 1С: Предприятия.

Справочник "Организации" в программном решении "Управление производственным предприятием" определяет, по какому количеству организаций Вы собираетесь вести учет в текущей базе данных. Таким образом, в данном справочнике должна быть как минимум одна запись !

Программное обеспечение позволяет вести учет по нескольким своим организациям одновременно , используя общую базу данных. То есть, если у вас несколько юридических лиц, учет можно осуществлять в единой базе данных. При этом, каждая организация ведется как бы "сама по себе". То есть данные учета "не перемешиваются". Однако, если при формировании отчета не указать, по какой именно организации Вы хотите получить информацию - все данные будут выданы "в общей сумме". Если Вы хотите периодически видеть учетную информацию как вместе, так и отдельно по каждой своей организации - можете вести такой учет.

  • Пользователи иногда ошибаются при вводе данных, кто-то может указать "не свою" организацию (решается администрированием доступа к данным), кто-то может не указать ее вообще
  • База данных может быть изъята контролирующими органами, в результате чего им станет известна "лишняя" информация
  • Сбой базы данных автоматически "выводит из строя" все ваши предприятия

Впрочем, решать Вам.

Обратите внимание - справочник "Организации" хранит не список контрагентов, а только Ваши собственные организации, которые Вы контролируете (управляете ими). Для контрагентов предусмотрен другой справочник - "Контрагенты".

Ввод данных по Вашей организации

Как уже говорилось ранее, в справочнике "Организации" должна быть как минимум одна запись. Поэтому смело ее добавляем, заполняя все возможные поля.

Обратите внимание . Информация, которую Вы укажете в данной записи, будет выводиться чуть ли не на всех печатных документах - от накладных до счетов. Поэтому указывайте ее аккуратно и корректно, без ошибок!

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

"Юр./Физ.лицо" - назначение поля вполне очевидно. Примите во внимание, что неправильное заполнение данного реквизита приведет к неправильному начислению заработной платы.

"Головная организация" - необходимо заполнить только в том случае, если Вы решили, например, организовать учет по каждому из своих филиалов (отделений) отдельно, а потом собираетесь всю информацию консолидировать у себя. При этом филиалы или отделения не являются юридическими лицами, но на каждом из них должен вестись отдельный учет отдельными пользователями. В большинстве случаев этого делать не нужно.

"Префикс" - сочетание букв и/или цифр, которые программа будет автоматически добавлять перед номером каждого документа. Обычно необходим для того, чтобы различать документы своих организаций, когда они ведутся в одной общей базе данных. Если у Вас одна организация необходимости в этом нет. Впрочем, добавить его никто не запрещает.

"Основной банковский счет" - данная информация не имеет критического значения. Но именно из этого поля программа будет пытаться указать банковские реквизиты, если они предусмотрены в документе, который пытается ввести пользователь. То есть во все документы это значение будет подставляться по умолчанию.

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

"На дату" - дата, по состоянию на которую верна вводимая Вами информация. Поскольку любая организация находится в динамически меняющихся условиях, у нее может изменится расчетный счет, директор, адрес и т.д., то при редактировании этих данных в поле "на дату" необходимо указать число, с которого произошла смена этих реквизитов. Программа "запоминает", что, например, до 13 августа директором был "Петров", а после - "Сидоров". В результате при открытии документов до и после этой даты, в них будут отражаться соответствующая дате документа фамилия директора. То есть все данные реквизиты организации, которые находятся на одной странице вместе с полем "на дату" являются периодическими.

Назначение справочников

Справочник хранит список возможных значений того или иного объекта или реквизита. Справочники используются в тех случаях, когда необходимо исключить неоднозначный вв од информации. Например, для того, чтобы покупатель, продавец, кладовщик и директор понимали, о каком именно товаре идет речь, каждый должен называть его одинаково. И в этом случае нам необходим справочник. Обычно на торговом предприятии он имеет вид прайс-листа.

Система 1С:Предприятие 8 позволяет вести практически неограниченное количество необходимых справочников. Каждый справочник представляет собой список однородных объектов: должностей, сотрудников, клиентов, товаров и т. д. Каждый такой объект называется элементом справочника.

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

Реквизиты справочника (поля)

В качестве обязательных реквизитов каждый справочник имеет Код и Наименование . Код элемента справочника может быть как числовым, так и текстовым. Система 1С:Предприятие 8 предоставляет широкие возможности по работе с кодами элементов справочника: автоматическое присвоение кодов, автоматический контроль уникальности кода и другие.

Помимо Кода и Наименования, в справочниках системы 1С:Предприятие может храниться любая дополнительная информация об элементе справочника. Для хранения такой информации в справочнике могут быть созданы дополнительные реквизиты (поля). Используя механизм реквизитов справочника, легко организовать, например, картотеку сотрудников. Например, справочник Сотрудники почти наверняка будет иметь реквизиты Должность, Оклад, ДатаПриема и другие. Фирма 1С предвосхитила программистов и ввела во все справочники два обязательных (предопределенных) реквизита: Код и Наименование. Действительно, практически любой объект из реальной жизни содержит эти атрибуты. Например, для сотрудников кодом выступает табельный номер, а наименованием - Фамилия, Имя и Отчество (ФИО). Кроме того, использование кодов (при использовании автоматической нумерации) позволяет с легкостью понять, какой элемент был введен раньше, а какой позже в базу данных.

Типы данных

Для каждого реквизита справочника необходимо задать тип данных, например, "число", "строка", "дата", булево (Истина или Ложь). Это базовые типы, но можно указать и сложные типы данных. Например, реквизит Должность имеет тип данных Должности. В этом случае, значения этого реквизита будут выбираться из справочника Должности. Так реализуется простейшая связь между справочниками, когда значения реквизитов одного справочника выбираются из элементов другого справочника.

Иерархические справочники

Список элементов справочника в системе 1С:Предприятие 8 может быть многоуровневым. В этом случае все строки справочника будут разделяться на 2 вида: «просто» элементы справочника и группы справочника. Группы позволяют переходить на нижележащие уровни многоуровневого справочника. Использование многоуровневых справочников позволяет организовать ввод информации в справочник с нужной степенью детализации. Элементы и группы элементов в многоуровневом справочнике можно переносить из одной группы в другую.

Подчиненные справочники

Между справочниками может быть установлено отношение подчиненности. В терминах реляционных баз данных, между таблицами устанавливается связь "один-ко-многим". В этом случае каждый элемент подчиненного справочника будет связан с одним из элементов справочника-владельца. Иногда можно сказать, что элементы одного справочника принадлежат элементам другого. Например, в системе может быть справочник Договора. Тогда его можно сделать подчиненным справочнику Клиенты. Это означает, что клиент владеет договорами и у одного клиента может быть несколько договоров.

Табличные части

Начиная с версии 1С 8.0, в платформе реализована возможность для элемента справочника задавать одну или несколько табличных частей. Эту возможность рекомендуется использовать для отражения информации, связанной с данным элементом, но не имеющей собственной объектной сущности (для которых рекомендуется заводить подчиненные справочники). Например, для справочника Сотрудники могут быть заведены табличные части Образование и СоставСемьи. Работа с табличными частями похожа на работу с подчиненными справочниками за исключением того, что табличные части не могут использоваться в качестве значений реквизитов других объектов.

Где используется программный код для работы со справочниками?

Так как для выполнения программного кода нам необходимо обращаться к базе данных, данные куски программного кода должны размещаться в процедурах и функциях (или модулях) выполняемых на стороне сервера . Дополнительную информацию смотри в разделе .

1. Ссылка на справочник

Для работы со справочником из какого-либо модуля требуется сначала создать ссылку на этот справочник.

СпрСотрудники = Справочники . Сотрудники ; // или 2 вариант
СпрДолжности = Справочники [ "Должности"];

2. Создание и запись нового элемента справочника

НовЭл = Справочники . Сотрудники . СоздатьЭлемент ();
НовЭл . Наименование = "Петров Петр Петрович";
НовЭл . Оклад = 25000;
НовЭл . Записать (); // именно в этот момент происходит запись в базу данных

3. Создание и запись новой группы справочника (для иерархического справочника)

Нов = Справочники.Сотрудники . СоздатьГруппу ();

Нов . Записать ();
// или 2 вариант
Нов = Справочники [ "Сотрудники"]. СоздатьГруппу ();
Нов . Наименование = "Работающие";
Нов . Записать ();

4. Поиск элемента справочника

// если элемент найден, то он возвращается, иначе возвращается значение Неопределено

НайденныйСотр = СпрСотр . НайтиПоКоду (123); //ищем по коду
НайденныйСотр = СпрСотр . НайтиПоНаименованию ("Иванов Иван Иванович"); //по наименованию
НайденныйСотр = СпрСотр . НайтиПоРеквизиту ("Оклад", 5000); //по реквизиту

Если НайденныйСотр = Неопределено Тогда
//элемент не найден
КонецЕсли;

5. Удаление элемента справочника

СпрСотр = Справочники . Сотрудники ;

СпрСотр . Удалить (); //непосредственное удаление текущего элемента справочника

СпрСотр . УстановитьПометкуУдаления (Истина); //пометка на удаление
СпрСотр . УстановитьПометкуУдаления (Ложь); //снять пометку на удаление

//можно проверить, помечен ли элемент на удаление
//свойство ПометкаУдаления имеет тип Булево (Истина или Ложь)

Пометка = СпрСотр . ПометкаУдаления ; //обратите внимание: это свойство
Если Пометка = Истина Тогда
//элемент помечен на удаление
КонецЕсли;

6. Перебор элементов справочника

Выборка = Справочники . Сотрудники.Выбрать ();
// начало перебора элементов справочника в цикле
//действия с очередным элементом...

КонецЦикла;

7. Родитель. Перебор элементов внутри группы.

Группа в терминах 1С - это "родитель".

СпрСотр = Справочники . Сотрудники ;
ГруппаРаботающие = СпрСотр . НайтиПоНаименованию ("Работающие");
Выборка = СпрСотр . Выбрать (ГруппаРаботающие );
Пока Выборка . Следующий () = 1 Цикл

Сообщить ("Сотрудник " + Выборка . Наименование );
КонецЦикла;

8. Владелец. Перебор элементов справочника, принадлежащих элементу другого справочника.

Один справочник подчинен другому справочнику, например справочник НалоговыеЛьготы подчинен справочнику Сотрудники.

Выборка = Справочники . НалоговыеЛьготы . Выбрать (, Сотрудник ); //тут сотрудник - ссылка на элемент справочника сотрудники
Пока Выборка . Следующий () = 1 Цикл
//действия с очередным элементом
Сообщить ("льгота " + Выборка . Наименование );
КонецЦикла;


9. Транзакция

При создании множества элементов справочника для ускорения работы можно заключить цикл в транзакцию. При этом реальное создание всех элементов произойдет только по команде ЗафиксироватьТранзакцию(). При использовании транзакций действие будет либо выполнено целиком (созданы все элементы справочника), либо не выполнено совсем (в случае какого-либо сбоя не будет создано ни одного нового элемента, все останется также, как до запуска транзакции). Транзакции широко применяются в банковской сфере. Ведь никто не хочет, чтобы при отправке денег, они благополучно списались с вашего счета, но из-за какого-либо сбоя не дошли до адресата.

СпрСотр = Справочники . Сотрудники ;
НачатьТранзакцию ();

Для Ном = 1 По 100 Цикл
Нов = СпрСотр . СоздатьЭлемент ();
Нов . Наименование = "Новый " + Строка(Ном );
Нов . Записать ();
КонецЦикла;

ЗафиксироватьТранзакцию ();