Вспомогательная подсистема для штрихкодирования объектов базы

08.01.18

Задачи пользователя - Подбор и обработка объектов

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

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Вспомогательная подсистема для штрихкодирования объектов базы
.cf 7,47Mb ver:18-01-07/1
8
8 Скачать (10 SM) Купить за 4 550 руб.

Не так давно попалась публикация на тему штрихкодирования объектов информационной базы.

//infostart.ru/public/722123/

Естественно, что вариантов решения по этой теме может быть море, но после ознакомления с данной публикацией и комментариями, которыми она обросла, хочется внести очередные 5 копеек и представить свое решение по данному вопросу, которое было проверено в условиях реальной эксплуатации на самописной конфигурации для логистики и, в небольшом объеме, на УПП.

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

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

Учитывая все входные условия пришел к формуле, позволяющей закодировать в базе все, что требуется:

BBPPPPPPYYYYMMDDHHmmSSOOOOOOFFFF (28 + 4 символов)

ГДЕ:

BB (2 знака)       - префикс информационной базы, сгенерировавшей код. Актуально для распределенных БД. Настраивается в регистре сведений "Префикс ИБ" (шосПрефиксИБ). Значение по умолчанию – «00»

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

YYYYMMDDHHmmSS (14 знаков) - дата и время генерации штрихкода

OOOOOO  (6 знаков) - порядковый номер сгенерированного в пределах одной секунды объекта

FFFF  (4 знаков) - суффикс печатной формы. Выводится только при печати документов, в БД не хранится, если при печати суффикс не указан выводится "0000"

Непосредственно генерацию штрихкода выполняет специально созданная подписка на событие «При записи» для «СправочникОбъект» и «ДокументОбъект». Штрихкоды назначаются только тем типам объектов, которые были указаны в настройках (регистр шосНастройкаШтрихкодированияОбъектовСистемы). Сгенерированный код записывается в регистр шосКодыОбъектовСистемы, который может использоваться для поиска объектов или выведения на печать.

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

 

Если все хорошо, то при записи объектов, типы которых выбраны в настройках, должны генерироваться штрихкоды, по правилам, которые описаны выше.

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

Подсистема штрихкодирование

См. также

ККМ Кассовые операции Подбор и обработка объектов Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Россия Платные (руб)

Модуль, ускоряющий подбор номенклатуры в 1С в чек ККМ и Заказе клиента. Оптимизированная форма подбора товаров с многократно ускоренным процессом поиска товаров в 1С в чек ККМ и Заказе клиента для конфигураций 1C:Управление торговлей 11.5, 1С:Комплексная Автоматизации 2.5 и 1С:ERP Управление предприятием 2.5

18000 руб.

30.10.2024    880    2    0    

4

Подбор и обработка объектов Пользователь Платформа 1С v8.3 1С:Управление торговлей 11 Россия Платные (руб)

Решение реализовано посредством расширения, предназначено для дополнительного контроля объектов (документов и справочников) от несанкционированного доступа и изменения. При этом используется не штатный механизм 1С, требующий зачастую достаточного опыта, а предельно упрощенный для пользователя - установить/снять галку «Проверен» для регулировки доступа к объекту.

3600 руб.

13.09.2024    581    1    0    

3

Подбор и обработка объектов Программист Бухгалтер Пользователь Платформа 1С v8.3 Абонемент ($m)

Горыныч - универсальная внешняя обработка группового многопоточного проведения. Работает в одном потоке в любой конфигурации, многопоточный режим доступен при наличии справочника «Склады».

10 стартмани

29.04.2025    2875    3    DmitryKSL    7    

15

Подбор и обработка объектов Программист Платформа 1С v8.3 Россия Абонемент ($m)

Массовая работа с объектами типовыми методами платформы 1С.

10 стартмани

13.12.2024    935    4    nomad_irk    5    

4

Подбор и обработка объектов Программист Платформа 1С v8.3 1С:Управление нашей фирмой 3.0 Россия Абонемент ($m)

Обработка, очищающая двойные записи в регистре "График платежей". Решает проблему: Обнаружено дублирование ключевых значений в колонках: "Ссылка". Отображение данных в списке невозможно.

1 стартмани

26.09.2024    748    2    AlexHelmer    0    

4

Зарплата Подбор и обработка объектов Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Абонемент ($m)

После расчета и выплаты отпускных порой отпускные приходится пересчитывать. Причины: начислена годовая премия, или начислена зарплата, входящая в расчетную базу, и прочие. Делать вручную - непрактично. Можно воспользоваться отчетами (типовых, к слову, нет), но потом еще надо вручную создавать документы-исправления. Данная обработка автоматизирует весь процесс по принципу Plug-n-Play.

3 стартмани

14.08.2024    890    18    Vinzor    0    

5

Поиск данных Корректировка данных Подбор и обработка объектов Программист Пользователь Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Абонемент ($m)

Обработка позволяет найти и заменить битые ссылки справочников. Для всех конфигураций. Обработка универсальная! Незаменимая вещь как для IT-специалистов, так и для обычных пользователей!

10 стартмани

04.07.2024    1342    9    user1527257    2    

5

Корректировка данных Подбор и обработка объектов Пользователь Платформа 1С v8.3 1C:Бухгалтерия Абонемент ($m)

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

10 стартмани

28.06.2024    1133    9    user1527257    0    

9
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. CheBurator 3230 09.01.18 19:33 Сейчас в теме
А почему не кодировать в ШК гуид?
2. Infector 205 09.01.18 20:01 Сейчас в теме
(1) в общем-то кодировать его никто и ничто не мешает. Но как минимум два аспекта не очень приятных - он во-первых для code128 он длиннее, даже если развернуть его в десятичное число. Во-вторых его использование предполагает, что вам заранее известно какой тип объекта положен в основу кода и по какой таблице выполнять поиск при считывании.
3. CheBurator 3230 09.01.18 20:27 Сейчас в теме
...второй пункт я упустил...
4. genayo 09.01.18 20:58 Сейчас в теме
Если печатная форма распечатывается в одной базе (например, в бухгалтерии), а документ по этому штрихкоду надо найти в другой (например, УТ) нужно подсистему в обе встраивать?
5. Infector 205 09.01.18 21:18 Сейчас в теме
(4) как минимум регистр со связкой сгенерированных кодов и объектов, которым они соответствуют. Плюс в обмен его включить. Без остального в принципе можно и обойтись, если задача по генерации во второй базе не стоит. Возможно только, что микроисправления понадобятся, но маловероятно.
6. webcisp 11.03.18 12:21 Сейчас в теме
из описания непонятно что за объекты надо вставлять в конкретные документы, и будет ли работать на обычных формах и внешних печатных формах - прошу уточнения или помощи в настройке ..
7. Infector 205 11.03.18 18:06 Сейчас в теме
(6) в конфигурацию нужно встроить дополнительные объекты с префиксом "шос" и затем настроить в соответствующем регистре сведений генерацию. Для того, чтобы работала генерация изменений в типовых объектах не нужно. Обычных форм не создавал, т.к. обычное приложение управляемыми формами пользоваться умеет. Касательно вывода сгенерированных значений в печатные формы ничего не писал, т.к. большая часть здешней публики с этим проблем не испытывает. Со внешними печатными формами естественно будет работать.
8. webcisp 11.03.18 18:24 Сейчас в теме
Благодарю за ответ . Здесь также есть часть публики, т.е. участников, которые не умеют программировать в 1С :) Вы сможете мне оказать услугу по настройке моего конфига и парочки документов ?
9. Infector 205 11.03.18 18:37 Сейчас в теме
Оставьте свое сообщение