Штрихкодирование в УТ 10.3 с дальнейшим распознавание в 1С:Документооборот КОРП

04.04.14

Разработка - Разработка внешних компонент

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
База с реализацией штрихкодирования
.dt 28,68Kb ver:1
37
37 Скачать (1 SM) Купить за 1 850 руб.

Предисловие:

Решение покупки 1С:Документооборот (далее ДО) конечно же поступило от нашего руководства. Пришла девушка, показала, понравилось (насчёт самой девушки не знаю, не работал я ещё тут... но наверно тоже понравилась  Embarassed ) и было принято решение о внедрении.

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

Тут мог бы быть анекдот, но разобрался я с ДО достаточно быстро, хоть и до сих пор не знаю полностью всех фишек.

Сегодня же поговорим о таком понятии как "Потоковое сканирование", которое позволяет сканировать документы, распознавать Штрих-коды и привязывать их к различным документам или справочникам.

Смысл следующий, мы настраиваем сканирование, выбираем вариант распознавания штрих-кода, либо встроенный, либо (об этом будет попозже), кладём бумажки в сканер и ждём когда программа все сделает. Красота, правда ведь! Но в реалиях нужны были изменения...

 

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

Со штрихкодированием я раньше сталкивался, поэтому сразу же приступил к формированию структуры.

Выглядит она примерно так:

  1. Первый символ – Тип документа/справочника
  2. Второй символ – Тип печатной формы
  3. 12 символов – номер документа/справочника
  4. 3 символа – дата, если это документ, и «000», если справочник

Тип штрих-кода взял Code-128, так как он больше всего подходит для формирования такой структуры.

Сказано, сделано. Настроил формирование, хотя и некоторые сложности были, вывел на печать, проверил сканером ШК, всё замечательно. Иду к сканеру, кладу бумагу, запускаю обработку «Потоковое сканирование» и жду… Выходит сообщение о том, что сканирование прошло успешно, файл загрузился, но не привязался ни к какому документу, из-за того, что не был найдет по штрих-коду. Пока всё правильно и логично, дальше спускаемся в недра конфигуратора…

Путём нехитрых точек останова нахожу место, где с помощью компоненты «CuneiForm» читается штрих-код, смотрю строку прочитанного значения… пусто. Уменьшаю шаг поиска штрих-кода с 10 до 6 мм, запускаю повторно. Уже не пусто, но что-то не то. А именно, что распознал 13 цифр, которые вообще с потолка взяты. Лезу в конфигуратор, компоненте просто передается путь картинки и шаг, дальше она все делает сама… Никакого указания типа штрих-кода нет.

Печатаю штрих-код документа ДО, сканирую, всё прекрасно. Прочитал, прилепил, обещанная красота!

Выходит, EAN13 он читает нормально, а Code-128 не хочет?

Отправляемся на сайт разработчика компоненты. Но то ли человеческая лень, то ли отсутствие документации заставляют меня обратить в службу поддержки с логичным вопросом: «А что у нас с Code-128?». На что мне приходит следующее сообщение:

То есть, чтобы Code-128 читал, нужно ещё денег отдавать, и неизвестно ещё как поведёт себя компонента с 1С. Будет ли нормально читать символы? Потребуется ли донастройка?

Письмо я отправил сразу же. Текст примерно такой: «Мужики, а сколько это стоить то будет? И можно получить Trial-версию потестировать хотя бы?»

Ответа жду уже неделю и честно больше ждать и не хочется и не надо. За это время я узнал, что в 1С прописана возможность распознавания штрих-кода с помощью «ABBYY Recognition Server», скорее всего она распознаёт абсолютно любой тип штрих-кода, как мне их менеджер объяснял, но стоимость на тот момент… От 180 до 600 т.р. в зависимости от количества сканируемых документов…

 

Попытка номер два:

Конечно же никто такие деньги давать не стал, тем более на достаточно раннем этапе внедрения ДО. Хоть мы компания не маленькая, но на каждые бантики столько тратить…

Значит нужно подвести нашу структуру к EAN13. Для это сначала идем в ДО и смотрим как у них все настроено, чтобы сделать по аналогии.

В итоге конечно я поизобретал велосипед, но смысл заключается в следующем:

В ДО первый символ внутренних документов всегда «2», так прописано в коде. Кто не верит, Общий модуль «ШтрихкодированиеСервер. СформироватьШтрихКод()».  Для документов из Управления торговлей я решил взять первым символом «5». Таким образом, можно указать ещё 11 цифр и 1 контрольный символ. Штрих-код должен быть привязан ко всем документам не зависимо от наличия у них печатных форм. Потом надо добавить к этому штрих-коду тип печатной формы.

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

Поэтому создаем подписку на событие, которая будет добавлять запись в регистр с ссылкой документа и его штрих-кодом. Это будет просто последовательность. «500000000001», «500000000002», «500000000003» и т.д.

Для того, чтобы указать тип печатной формы, я взял 2 символа после «5».

Соответствия типов печатных форм и их цифр записываем в новый регистр сведений. Таким образом штрих-код при печати будет примерно таким: «504000000078».

Однако записывать все штрих-коды печатных форм в регистр не имеет смысла. Формирование по типу будет в момент печати. То есть, во время печати мы меняем второй и третий символы на то, что у нас указано в регистре сведения соответствий.

После первой попытки сканирования документов с таким штрих-кодом ДО распознал всё правильно, и теперь его можно обрабатывать после сканирования.

Осталось только описать добавление штрих-кода на печатную форму и обработку в ДО.

 

Полезная информация (?):

Чтобы добавить штрих-код на печатную форму, нужно установить компоненту «1CBarCode.exe». Для этого ее предварительно нужно скачать:

Дальше открываем печатную форму в конфигураторе, по меню идём «Таблица» -> «Рисунки» -> «Вставить объект…», располагаем её на форме.

Потом выбираем компоненту как на рисунке:

Описывать все настройки не буду, если появятся вопросы, можете написать в ЛС или «погуглить», по этой компоненте очень большое количество документации.

Дальше указываем текст, который будет в штрих-коде и выводим на печать… Вот и всё!

 

Теперь немного про обработку строки штрих-кода…

Всё тот же общий модуль «ШтрихкодированиеСервер», функция «НайтиОбъектыПоШтрихкоду».

Есть несколько подходов, я приведу полтора:

1.    Обрабатываем сразу при получении, для этого необходимо подключаться с помощью ComConnector, получать через штрих-код документ из регистра, а оттуда нужные данные, анализировать их и тип печатной формы, дальше «что-то делать» (придумай сам или спроси у начальства).

Плюсы очевидны: всё делается в реальном времени.

Минусы тоже очевидны: Если у вас больше одного человека, который всем этим занимается, то это «сжирание» свободных лицензий, куча обращений к внешней базе и т.д. и т.п.

2.    Вариант «1.5» Добавляем в существующий регистр сведений «Штрихкоды» в ДО новый ресурс «Обработано» тип булево (либо создаём новый РС), делаем в него записи при сканировании, после чего по регламентному заданию обрабатываем так же через ComConnector.

 

Вот наверно и всё, чем я хотел бы поделиться относительно этой темы…

В прикреплениях есть архив конфигурации с регистрами и общим модулем «Штрихкодирование», в котором кстати есть методы для первого подхода к решению задачи.

 

Дополнительно к варианту номер 2 (04.04.2014):

Метод создания штрихкода, предложенный во втором варианте адекватен только для одной базы, для распределенных он не подходит, т.к. один и тот же штрихкод может быть присвоен разным документам. Можно создавать случайно генерируемый номер ШК.

Для это необходимо в функции "СоздатьНовыйШтрихкодДокумента(Источник)" изменить его формирование.

Примером может служить данный вариант (не самый оригинальный, но вполне живой):

// Получение нового Штрихкода для документа
//
Функция СоздатьНовыйШтрихкодДокумента(Источник)
    
    Если Найти(ТипЗнч(Источник), "Документ") = 0 Тогда
        Возврат "000000000000"; // Пока только документы
    КонецЕсли;
    
    НачальноеЧисло = 0;
    
    День = Число(Строка(День(ТекущаяДата())));
    Месяц = Число(Строка(Месяц(ТекущаяДата())));
    Год = Число(Строка(Год(ТекущаяДата())));
    
    МоментВремени = Число(Строка(Секунда(ТекущаяДата())) + Строка(Минута(ТекущаяДата())) + Строка(Час(ТекущаяДата())) + Строка(День) + Строка(Месяц) + Строка(Год));
    ДопПараметр1 = Число(ПреобразоватьШКПриДобавленииЧисла(Источник.Номер, 0));
    ДопПараметр2 = СокрЛП(Новый УникальныйИдентификатор);
    
    //оставляем только цифры
    ДопПараметр2 = СтрЗаменить(ДопПараметр2, "-", "");
    ДопПараметр2 = СтрЗаменить(ДопПараметр2, "a", "");
    ДопПараметр2 = СтрЗаменить(ДопПараметр2, "b", "");
    ДопПараметр2 = СтрЗаменить(ДопПараметр2, "c", "");
    ДопПараметр2 = СтрЗаменить(ДопПараметр2, "d", "");
    ДопПараметр2 = СтрЗаменить(ДопПараметр2, "e", "");
    ДопПараметр2 = СтрЗаменить(ДопПараметр2, "f", "");
    
    ДопПараметр2 = Число(ДопПараметр2);
    
    НачальноеЧисло = ДопПараметр2 * ДопПараметр1 / МоментВремени;
    
    ГСЧ = Новый ГенераторСлучайныхЧисел(НачальноеЧисло);
    ПредставлениеНачальногоЧисла = ПреобразоватьШКПриДобавленииЧисла(ГСЧ.СлучайноеЧисло(0, 999999999), 0);
    
    Пока СтрДлина(ПредставлениеНачальногоЧисла) < 9 Цикл
        Результат = "0" + НачальноеЧисло;
    КонецЦикла;
    
    СтрокаГод = Прав(Год, 1);
    
    Результат = СтрокаГод + "00" + ПредставлениеНачальногоЧисла;
    
    Запрос = Новый Запрос;
    Запрос.УстановитьПараметр("ПроверкаРезультата", Результат);
    Запрос.Текст = "ВЫБРАТЬ ПЕРВЫЕ 1
        |    ШтрихкодыДокументов.Штрихкод КАК Штрихкод
        |ИЗ
        |    РегистрСведений.ШтрихкодыДокументов КАК ШтрихкодыДокументов
        |ГДЕ
        |    ШтрихкодыДокументов.Штрихкод = &ПроверкаРезультата";
    
    Выборка = Запрос.Выполнить().Выбрать();
    Если Выборка.Следующий() Тогда
        Результат = СоздатьНовыйШтрихкодДокумента(Источник);
        Возврат Результат;
    КонецЕсли;
    
    Возврат Результат;
    
КонецФункции // СоздатьНовыйШтрихкодДокумента()

 

Потоковое сканирование 1С:Документооборот Документооборот Штрихкод

См. также

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Позволяет автоматизировать работу с картинками. С помощью компоненты можно измерять размер изображений, поворачивать их, наносить водяные знаки, конвертировать из одного формата в другой. Будет очень полезна для интернет-магазинов и всех, кому постоянно требуется работать с различными графическими форматами. Выполнена по технологии NativeAPI. Работает с форматами: jpg (jpeg), png, bmp, gif, tif

3600 руб.

02.09.2010    77780    73    257    

191

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 Платные (руб)

Внешняя компонента позволяет работать c TWAIN-совместимым оборудованием (сканерами, камерами) . Полностью совместима со стандартной TWAIN-компонентой из БСП и может применяться как ее замена без изменения вызовов, при этом может работать с 64-разрядной платформой, а так же имеет расширенную функциональность, например, сохранение результата непосредственно в PDF без использования сторонних утилит. Прекрасно работает на сервере, тонком клиенте и веб-клиенте (проверена работа в браузерах Google Chrome, Mozilla Firefox и Microsoft Internet Explorer).

3000 руб.

12.05.2020    29065    139    100    

92

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Внешняя компонента позволяет печатать PDF файлы непосредственно из 1С, не используя при этом сторонних программ. Прекрасно работает на сервере, тонком клиенте и веб-клиенте. Основана на проекте PDFium из состава проекта Chromium/Chrome

1500 руб.

17.09.2018    37130    115    128    

116

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

Внешняя компонента для конвертации PDF файлов в картинки без использования дополнительных программ. Работает на сервере и в тонком клиенте.

2400 руб.

25.06.2024    1311    3    4    

3

Разработка внешних компонент Системный администратор Программист Стажер Бесплатно (free)

Библиотека для работы с базами SQLite из 1С на основе внешней компоненты. Для Linux и Windows, бесплатно и с открытым исходным кодом!

14.01.2025    2626    bayselonarrend    14    

48

Разработка внешних компонент Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Бесплатно (free)

В статье описывается приложение-конструктор внешних компонент (native API). Конструктор упрощает процесс разработки за счет удобного добавления всех нужных функций и процедур в графическом режиме, с указанием их параметров и типов параметров. На выходе приложение генерирует готовый код на С++ и Rust и позволяет сразу приступить к реализации, без настройки API компоненты вручную.

04.12.2024    5384    kovalevdmv    26    

77

Разработка внешних компонент Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Некоторые практические аспекты создания внешних компонент на языке С++ для платформы 1С 8.3++.

26.01.2024    7830    starik-2005    40    

47
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. anig99 2855 03.04.14 11:37 Сейчас в теме
Плохо ищете решения, товарищ...
http://zbar.sourceforge.net/ - вот бесплатно для распознавания штрихкодов.
http://programmersforum.ru/showthread.php?p=992391 - вот так это использовать
2. Draconus 85 03.04.14 13:02 Сейчас в теме
Дэлфя - хорошо, и под 1С тоже думаю можно. Однако несколько сложнее для тех кто никогда с компонентами не сталкивался. Здесь же используем типовую, которую 1С предлагает.
3. anig99 2855 03.04.14 18:03 Сейчас в теме
(2) типовая для распознавания штрихкода? Это CuneiForm то типовая от 1с?
А в предлагаемой ссылке №2 внизу есть описание как организовать распознавание через командную строку. А уж про работу с shell в 1с много есть примеров.
4. Draconus 85 04.04.14 08:51 Сейчас в теме
(3) anig99, раз она идёт в типовой поставке, то да, логично её назвать "типовой", особенно что уже есть для неё все настройки. Что Вас удивляет?
Так же интересно чтобы предложенная Вами компонента, автоматом при сканировании со сканера распознавала ШК. Думаю там переписывать больше надо. В любом случае предложенный вариант имеет смысл на жизнь и вполне нормально отрабатывает с небольшими изменениями конфы.
5. anig99 2855 04.04.14 18:45 Сейчас в теме
(4) хм. ничего переписывать не надо. Это не компонента, а программа.
есть 2 решения:
1. рисуем кнопку Сканировать в 1с. Сканирование средствами 1с, сохранение в файл, вызов командной строки для распознавания штрихкода, чтение результат распознавания, поиск документа, сохранение отсканированного файла в базу
2. на первом этапе нет сканирования в 1с, а есть фоновое задание по поиску новых файлов определенной папке, куда её скидывают пользователи (тупо настройки сканера на папку, куда скидывать). Потом распознавание и т.д.

2ой вариант предпочтительнее
6. МимохожийОднако 142 30.07.16 07:49 Сейчас в теме
(2) при рассмотрении регистра сведений ШтрихкодыДокументов возник вопрос. Почему Штрихкод размещен в измерениях, а не в ресурсах? Так и задумано, чтобы у одного документа было несколько штрихкодов?
Есть пример кода для получения штрихкода для разных печатных форм?
7. Draconus 85 13.10.16 11:09 Сейчас в теме
(6) МимохожийОднако, да, одному документу несколько ШК, так как записывается на просто ШК документа, но и ШК каждой печатной формы документы, для дальнейшей идентификации. Насколько я помню - в базе был пример.
Оставьте свое сообщение