Бегство из Frontol в Далион или очередной день программиста

22.09.16

Интеграция - ККМ

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

Скачать файлы

Наименование Файл Версия Размер
ЗагрузитьИзFrontolDBF
.epf 8,64Kb
13
.epf 8,64Kb 13 Скачать

Немножко предыстории.

Все началось с того, что сломался очередной жесткий диск и, как всегда, копий нет. Но есть рабочая касса под руководством программы FRONTOL 4 и нужно быстро реанимировать 1С хотя бы в части справочника номенклатуры, ну и цен соответственно.

Учет ведется в программе Далион:УНО (ПРО, Сеть)

Для того, чтобы все это осуществить, нам понадобится программа, которая умеет экспортировать из базы данных INTERBASE/FIRIBERD в Exсel или DBF,  я использовал вот такую:

IBExpert (http://www.ibexpert.net/ibe/index.php) (не спрашивайте, где брать не демо).

  1. Экспортируем следующие таблицы: SPRT -- SPRT.DBF, PRICEDATA -- PRICEDAT.DBF, BARCODE -- BARCODE.DBF, REMAIN -- REMAIN.DBF (для тех, кто использует сложные разрезы цен, думайте сами)
  2. Восстанавливаем чистую базу из шаблона или другим способом
  3. Запускаем обработку указываем ей каталог (жестко прописан, выбор не работает).
  4. После всего этого работать будет все, кроме выгрузки  в кассу.

Чтобы заработала выгрузка в кассу, нужно или заново перезаписать каждую группу, или написать обработку, которая заполнит регистр сведений "АссортиментСкладов"

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

Функция ОткрытьТаблицуDBF(ИмяТаблицы)
    xbase = Новый xBase; xBase.ОткрытьФайл(ИмяТаблицы);
    Если xBase.Открыта() Тогда    Возврат xBase; иначе Возврат Неопределено; КонецЕсли;
КонецФункции

Процедура СкопироватьxBaseВТЗ(xBase,ТЗн)
    xBase.Первая();
    Пока НЕ xBase.вКонце() Цикл
        НоваяСтрока = ТЗн.Добавить();ЗаполнитьЗначенияСвойств(НоваяСтрока,xBase); xBase.Следующая();    
    КонецЦикла;
КонецПроцедуры

Процедура КнопкаВыполнитьНажатие(Кнопка)
    xBaseТовары         = ОткрытьТаблицуDBF(СокрЛП(КаталогТаблиц)+"SPRT.DBF");
    xBaseШтрихКоды         = ОткрытьТаблицуDBF(СокрЛП(КаталогТаблиц)+"BARCODE.DBF");
    xBaseЦены             = ОткрытьТаблицуDBF(СокрЛП(КаталогТаблиц)+"PRICEDAT.DBF");
    xBaseЦеныОстатка     = ОткрытьТаблицуDBF(СокрЛП(КаталогТаблиц)+"REMAIN.DBF");
    Если xBaseТовары=Неопределено или xBaseШтрихКоды =Неопределено или
        xBaseЦены =Неопределено или xBaseЦеныОстатка =Неопределено Тогда
        Сообщить("не могу открыть таблицы SPRT.DBF BARCODE.DBF PRICEDAT.DBF REMAIN.DBF");
        Возврат;
    КонецЕсли;
    
    ТзнШтрихКоды = Новый таблицаЗначений;
    ТзнШтрихКоды.Колонки.Добавить("ID",Новый ОписаниеТипов("Число"));
    ТзнШтрихКоды.Колонки.Добавить("WareID",Новый ОписаниеТипов("Число"));
    ТзнШтрихКоды.Колонки.Добавить("Barcode",Новый ОписаниеТипов("Строка"));
    ТзнШтрихКоды.Колонки.Добавить("Factor",Новый ОписаниеТипов("Число"));
    
    ТзнЦены = Новый таблицаЗначений;
    ТзнЦены.Колонки.Добавить("ID",Новый ОписаниеТипов("Число"));
    ТзнЦены.Колонки.Добавить("Price",Новый ОписаниеТипов("Число"));
    ТзнЦены.Колонки.Добавить("RemainID",Новый ОписаниеТипов("Число"));    //брать из таблице remain поле ID
    
    ТзнЦеныОстатка = Новый таблицаЗначений;
    ТзнЦеныОстатка.Колонки.Добавить("ID",Новый ОписаниеТипов("Число"));
    ТзнЦеныОстатка.Колонки.Добавить("WareID",Новый ОписаниеТипов("Число"));
    
    ТзнТовары = Новый ТаблицаЗначений;
    ТзнТовары.Колонки.Добавить("ID",Новый ОписаниеТипов("Число"));
    ТзнТовары.Колонки.Добавить("PARENTID",Новый ОписаниеТипов("Число"));
    ТзнТовары.Колонки.Добавить("Code",Новый ОписаниеТипов("Число"));
    ТзнТовары.Колонки.Добавить("Name",Новый ОписаниеТипов("Строка"));
    ТзнТовары.Колонки.Добавить("Text",Новый ОписаниеТипов("Строка"));
    ТзнТовары.Колонки.Добавить("Flags",Новый ОписаниеТипов("Число"));    //Flags = //9727 весовой товар
                                                                        //9726 - обычный товар  254 - группа
    ТзнТовары.Колонки.Добавить("IsWare",Новый ОписаниеТипов("Число"));    // 1- Товар
    ТзнТовары.Колонки.Добавить("Номенклатура",Новый ОписаниеТипов("СправочникСсылка.Номенклатура"));
    
    СкопироватьxBaseВТЗ(xBaseШтрихКоды,ТзнШтрихКоды);
    СкопироватьxBaseВТЗ(xBaseЦены,ТзнЦены);
    СкопироватьxBaseВТЗ(xBaseЦеныОстатка,ТзнЦеныОстатка);
    
    Начатьтранзакцию();
    
    ДокАкт = Документы.АктПереоценки.СоздатьДокумент();
    ДокАкт.Дата = Рабочаядата;
    ЗаполнитьШапкуДокумента(ДокАкт, ПараметрыСеанса.ТекущийПользователь);
    ДокАкт.ВидОперации = Перечисления.ВидыОперацийАктПереоценки.Переоценка;
    ДокАкт.ТОСоздания = ПараметрыСеанса.ТекущийТО;
    УстановитьНомерДокумента(ДокАкт.ЭтотОбъект);
    ДокАкт.ЗаписыватьРасценку = УправлениеРИБ.ТребуетсяПодтверждениеПереоценки(ДокАкт);
    
    xBaseТовары.Первая();
    Пока НЕ xBaseТовары.вКонце() Цикл
        НоваяСтрока = ТзнТОвары.Добавить();
        ЗаполнитьЗначенияСвойств(НоваяСтрока,xBaseТовары);
        
        Если xBaseТовары.IsWare<>1 Тогда    
            НовЭлем = Справочники.Номенклатура.СоздатьГруппу();
            НовЭлем.Код = xBaseТовары.Code;
            НовЭлем.Наименование = xBaseТовары.Name;
            НовЭлем.Записать();
            
            НоваяСтрока.Номенклатура = НовЭлем.Ссылка;    // для идетификации групп
            
            Если  xBaseТовары.PARENTID <> 0  Тогда
                НайденаяГруппа = ТзнТовары.Найти(xBaseТовары.PARENTID,"ID" );
                Если НЕ НайденаяГруппа=неопределено Тогда
                    НовЭлем.Родитель =НайденаяГруппа.Номенклатура;
                    НовЭлем.Записать();
                КонецЕсли;
            КонецЕсли;
        КонецЕсли;
        xBaseТовары.Следующая();
    КонецЦикла;
    
    Для каждого СтрокаТзн Из ТзнТОвары Цикл
        Если СтрокаТзн.IsWare <> 1 Тогда
            Продолжить;
        КонецЕсли;
        НовЭлем = Справочники.Номенклатура.СоздатьЭлемент();
        НовЭлем.Код             = СтрокаТзн.Code;
        НовЭлем.Наименование     = СтрокаТзн.Name;
        НовЭлем.НаименованиеПолное = СтрокаТзн.Text;
        
        НовЭлем.КатегорияТовара    = Справочники.КатегорииТоваров.УчетПоХарактеристикамНеВедется;
        Если Константы.УстанавливатьПроизводителяПоШК.Получить() Тогда
            НовЭлем.Производитель = Справочники.КлассификаторСтранМира.ПустаяСсылка();
        ИначеЕсли Не ЗначениеЗаполнено(НовЭлем.Производитель) Тогда
            НовЭлем.Производитель =  Константы.ОсновнойПроизводитель.Получить();
        КонецЕсли;
        НовЭлем.СтавкаНДС          = Константы.ОсновнаяСтавкаНДС.Получить();
        НовЭлем.ФирмаФР            = Константы.УправленческаяФирма.Получить();
        НовЭлем.ГруппаТоваровДляПривязкиКФР = Справочники.ГруппыТоваровДляПривязкиКФР.ОсновнаяГруппаТоваров;
        НовЭлем.ОсновноеИзображение = Справочники.ХранилищеДополнительнойИнформации.ПустаяСсылка();
            
        Если СтрокаТзн.Flags=9726 Тогда
            БазоваяЕдиницаОКЕИ = Константы.ОсновнаяЕдиницаОКЕИ.Получить();
        ИначеЕсли СтрокаТзн.Flags=9727 Тогда  
            БазоваяЕдиницаОКЕИ = Константы.ОсновнаяЕдиницаОКЕИВес.Получить();
            НовЭлем.ВыгружатьВВесы                 = истина;
            НовЭлем.РазрешеноДробноеКоличество     = истина;
            НовЭлем.ШтрихКодВключаетКоличество     = истина;
        Иначе
            БазоваяЕдиницаОКЕИ = Константы.ОсновнаяЕдиницаОКЕИ.Получить();
        КонецЕсли;
        НовЭлем.ОбменДанными.Загрузка = Истина;    //чтоб дал записать единицы измерения
        НовЭлем.Записать();
        
        НовЕдиница = Справочники.ЕдиницыИзмерения.СоздатьЭлемент();
        НовЕдиница.Владелец                 = НовЭлем.Ссылка;
        НовЕдиница.ЕдиницаПоКлассификатору     = БазоваяЕдиницаОКЕИ;
        НовЕдиница.Наименование             = БазоваяЕдиницаОКЕИ;
        НовЕдиница.Коэффициент                 = 1;
        НовЕдиница.Записать();
        
        НовЭлем.БазоваяЕдиницаИзмерения = НовЕдиница.Ссылка;
        НовЭлем.ЕдиницаИзмеренияОтчетов = НовЕдиница.Ссылка;
        НовЭлем.ЕдиницаИзмеренияЗаказов = НовЕдиница.Ссылка;
        НовЭлем.Записать();
        
        СтрокаТзн.Номенклатура = НовЭлем.Ссылка;
        
        Если  СтрокаТзн.PARENTID <> 0  Тогда
            НайденаяГруппа = ТзнТовары.Найти(СтрокаТзн.PARENTID,"ID" );
            Если НЕ НайденаяГруппа=неопределено Тогда
                НовЭлем.Родитель =НайденаяГруппа.Номенклатура;
                НовЭлем.Записать();
            КонецЕсли;
        КонецЕсли;
        
        НайденныеШтрихКоды = ТзнШтрихКоды.НайтиСтроки(Новый Структура("WareID",СтрокаТзн.ID));
        Для каждого СтрокаШтрихКод Из НайденныеШтрихКоды Цикл
            
            НаборЗаписей = РегистрыСведений.Штрихкоды.СоздатьНаборЗаписей();
            НаборЗаписей.Отбор.ШтрихКод.Установить(СокрЛП(СтрокаШтрихКод.Barcode));
            НаборЗаписей.Отбор.Номенклатура.Установить(НовЭлем.Ссылка);
            НаборЗаписей.Записать();
            
            НоваяЗапись = НаборЗаписей.Добавить();
            НоваяЗапись.Номенклатура     = НовЭлем.Ссылка;
            НоваяЗапись.Штрихкод         = СокрЛП(СтрокаШтрихКод.Barcode);
             НоваяЗапись.ТипШтрихкода     = ПланыВидовХарактеристик.ТипыШтрихкодов.EAN13;
            Новаязапись.ЕдиницаИзмерения= НовЭлем.БазоваяЕдиницаИзмерения;
            НаборЗаписей.Записать();
            
        КонецЦикла;
        //самое трудное
        найденыйостатокЦены = ТзнЦеныОстатка.Найти(СтрокаТзн.ID,"WareID");
        Если НЕ найденыйостатокЦены = Неопределено Тогда
            НайденнаяЦена             = ТзнЦены.найти(найденыйостатокЦены.ID,"RemainID");
            НоваяЦена                 = ДокАкт.Товары.Добавить();
            НоваяЦена.Номенклатура     = НовЭлем.Ссылка;
            НоваяЦена.Цена             = НайденнаяЦена.Price;
            //Сообщить("найденая цена "+СтрокаТзн.Code+" "+СтрокаТзн.Name+" "+НайденнаяЦена.Price);
        КонецЕсли;
    КонецЦикла;
    ДокАкт.Записать(РежимЗаписиДокумента.Запись);
    ЗафиксироватьТранзакцию();
КонецПроцедуры

Процедура КаталогТаблицНачалоВыбора(Элемент, СтандартнаяОбработка)
КонецПроцедуры

КаталогТаблиц = "D:\Supermarket\";

ВОТ ТАК И ЗАКОНЧИЛИСЬ ОЧЕРЕДНЫЕ БЕССОННЫЕ ВЫХОДНЫЕ.

Доработок не будет.

frontol Далион

См. также

Печать кассовых чеков на одну ККМ с нескольких рабочих мест для 1С:УТ11.х, КА2.х, Розница 2.х, УНФ, ERP 2.х, БП 3, БГУ2

ККМ Кассовые операции Розничная торговля Обмен с ГосИС Бухгалтерский учет Оперативный учет Управляемые формы 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

Расширение конфигурации для УТ 11.4, 11.5, КА 2.4, 2.5, Розница 3.0, 2.3 и 2.2, УНФ 1.6, УНФ 3x, ERP 2.4, 2.5, БП 3, БГУ2 (Управляемые формы) позволяет выполнять печать кассовых чеков на одну ККМ 54-ФЗ с нескольких рабочих мест. НИКАКИХ НАСТРОЕК В РАЗРАБОТКЕ - ПОДКЛЮЧИЛ И ПЕЧАТАЙ. Если у вас несколько отделов и одна ККМ - печатайте на одной ККМ! Если у вас две ККМ и одна поломалась - печатайте на одной ККМ, пока ремонтируете другую!

3500 руб.

27.08.2018    110328    906    559    

788

Обработка 1С для печати чеков на кассе ККТ АТОЛ.ОНЛАЙН

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

Печать чеков по документам 1С РеализацияТоваровУслуг (РасходнаяНакладная) и КорректировкаРеализации. Соответствует требованиям 54-ФЗ. Одна облачная касса может использоваться всеми подразделениями организации, без привязки к рабочим местам. Электронные чеки отправляются на email клиента и всегда доступны в 1С, по требованию можно распечатать. Легкая настройка: после регистрации кассы на сайте АТОЛ.ОНЛАЙН, в обработке необходимо указать логин, пароль и идентификатор группы ККТ (берутся в личном кабинете АТОЛ.ОНЛАЙН). Одну кассу можно использовать с 1С при расчетах с физ. и юр. лицами и для интернет-магазина. HTTPS протокол интеграции API v4 / ФФД 1.05 или API v5 / ФФД 1.2.

12000 руб.

23.08.2022    8712    17    2    

14

54-ФЗ. Очередь печати для ККМ. Обработки для подключения онлайн-касс к 1С 8 (поддержка Маркировки) + Эмулятор + ФФД 1.2

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

Обработка осуществляет обслуживание ККТ АТОЛ, Штрих и Меркурий для конфигураций "УТ 10.3", "КА 1.1", "УПП 1.3", "Розница 1.0", "БП 2.0" и других отраслевых решений, построенных на основе указанных выше конфигурациях. Поддерживает возможность параллельно пробития чеков на одной ККМ несколькими пользователями. Поддерживает Веб-сервер Атол. Соответствует требованиям 54-ФЗ. Поддерживает ФФД 1.0, 1.05, 1.1 и 1.2. Разделяет чеки по нескольким СНО. Поддерживает механизмы подключения ККТ по TCP/IP, для работы через RDP или интернет. Поддержка маркировки.

4200 руб.

25.05.2015    305152    1746    2966    

964

Обмен между 1С:Розница и Frontol 6 по организациям (Розница - Фронтол)

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

Обмен между 1С:Розница и Frontol 6 при торговле от нескольких организаций, а также ряд других полезных функций. Данный модуль незаменим для тех, кто ведёт учет по нескольким организациям в 1С:Розница, а на РМК (рабочее место кассира) установлен Frontol, или планируется его установка. Подходит для 1С:Розница редакция 3.0 и 1С:Розница редакция 2.3.

1500 руб.

22.03.2019    73814    339    467    

146

Заполнение авансовых отчетов и поступлений товаров по онлайн-чекам ФНС [Расширение для БП, КА2, ERP, УТ]

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

Позволяет загружать онлайн чеки в формате JSON из официального мобильного приложения "Проверка чеков ФНС" и заполнять документы «Авансовый отчет» и «Приобретение товаров». Помощник заполнения поможет найти /создать номенклатуру и номенклатуру поставщика по указанным настройкам и перенесет данные чеков в документы учетной системы. Данные чеков из мобильного приложения можно выгружать как по каждому чеку в отдельности, так и выпиской за период.

5400 руб.

09.06.2020    29428    107    39    

99

Сервер ККМ (54-ФЗ, быстрая печать чеков из терминального сеанса, печать с нескольких ПК)

ККМ Кассовые операции Розничная торговля Платформа 1С v8.3 Конфигурации 1cv8 Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Рестораны, кафе и фаст-фуд Россия Платные (руб)

"Сервер ККМ" позволяет приложениям работать с фискальными регистраторами из терминального сеанса Windows по локальной сети или интернет, организовать печать на одном ККМ с нескольких рабочих мест. Поддержка драйверов Атол, Штрих и VikiPrint. Поддержка 54-ФЗ. Поддержка ФФД 1.2. Подключается к 1С Торговля и склад 7.7, 1С:УТ 10/11, 1С:УНФ, 1С:Розница 1/2, 1С:БП 2/3, 1С КА 1/2., 1С:ERP, УПП

12000 руб.

02.09.2016    129827    277    189    

163

Выгрузка скидок и акций из 1С: Розница 2.3 и УТ 11.4, УТ 11.5, КА2(2.5) в Frontol 6

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

При работе в связке Розница или УТ - Frontol многие сталкиваются с проблемой создания скидок и маркетинговых мероприятий в Frontol, типовыми средствами из 1С: Розницы не предусмотрено выгрузки и создания акции. Для создания акции или дисконтных карт во Frontol, требовалось заводить в каждом Frontolе, если у вас несколько рабочих мест, что неудобно. При помощи обработки можно выгружать и создавать акции прямо из 1С: Розницы и УТ на любое рабочее место (оффлайн оборудование), выгружать информацию о картах, клиентах и назначить скидки на виды карт, что значительно упрощает процесс создания акции, и это может делать любой обученный оператор (товаровед) или бухгалтер.

3360 руб.

30.11.2021    18188    55    72    

32

54-ФЗ: Обработки для подключения онлайн-касс к 1С 8 (поддержка маркировки ФФД 1.2) + демо обработка + эмулятор

ККМ Кассовые операции Розничная торговля Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Обработки осуществляют обслуживание фискальных регистраторов, поддерживаемых драйвером "АТОЛ: Драйвер ККМ v.10.6", "ШТРИХ-М: Драйвер ККМ v 4.14", "ВИКИ: Драйвер CSI v 1.4", "СПАРК: Драйвер v1.0", "ПИОНЕР" Драйвер v1.0 для конфигураций "Бухгалтерия 2.0", "Управление торговлей 10.3" (релиз 10.3.40.1), "Комплексная автоматизация 1.1" (релиз 1.1.82.1), "Управление производственным предприятием 1.3" (релиз 1.3.87.1), "Розница 1.0" (релиз 1.0.19.16), соответствующих требованиям закона ФЗ-54 о применении контрольно-кассовой техники.Поддержка НДС 20%. Поддержка маркировки 488-ФЗ.

3000 руб.

02.02.2017    264628    544    2372    

551
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. maljaev 787 20.01.17 11:54 Сейчас в теме
Спасибо, помогло раскрутить связку tranzt-sprt-remain-pricedata при построении запроса.
P.S. Кстати да, а чего ADODB и запросы не юзаешь-то? Зачем этот изврат с DBF?
2. sodrk 08.09.21 23:41 Сейчас в теме
Спасибо за обработку, круто выручила. Правда, что-то с кодировкой и при загрузке номенклатуры вместо русских букв загрузились кракозябры, потом исправил загрузкой из табличного документа с перезаписью наименований. 3 минуты работы
Оставьте свое сообщение