Удобная библиотека для .NET разработчиков, обменивающихся данными с 1с бухгалтерией

22.06.16

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

Мы считываем и записываем информацию для почти 1000 организаций, ведущихся в 1с Бухгалтерии, из своего прикладного кода на C#. Для облегчения этих задач мы написали LINQ-провайдер для работы с базами 1С. Библиотека доступна на github.

Скачать исходный код

Наименование Файл Версия Размер
simple1c.zip
.zip 370,54Kb
2
.zip 370,54Kb 2 Скачать
LINQ-провайдер поддерживает методы Select и Where, кроме того библиотека позволяет генерировать классы объектной модели непосредственно по конфигурации. Весь исходный код доступен в проекте на GitHub.

Основные возможности

Автоматическая генерация классов объектной модели по 1С-конфигурации:

Generator.exe -connectionString File=C:\my-1c-db;Usr=Администратор;Pwd= -namespaceRoot MyNameSpace.ObjectModel1C -scanItems Документ.СписаниеСРасчетногоСчета -sourcePath C:\sources\AwesomeSolution\ObjectModel1CProject\AutoGenerated 

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

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

Не навязываем механизм управления коннекциями. Здесь возможны различные варианты (ThreadLocal, Pool, пересоздание по таймауту, пересоздание при обрыве и т.п.), многое зависит от приложения и конкретных потребностей. Простейший пример чтобы начать работать:

    var connectorType = Type.GetTypeFromProgID("V83.COMConnector");
    dynamic connector = Activator.CreateInstance(connectorType);
    var globalContext = connector.Connect("File=C:\my-1c-db;Usr=Администратор;Pwd=");
    var dataContext = DataContextFactory.CreateCOM(globalContext, typeof(Контрагенты).Assembly);
    var контрагент = new Контрагенты
    {
        ИНН = "1234567890",
        Наименование = "test-counterparty",
        ЮридическоеФизическоеЛицо = ЮридическоеФизическоеЛицо.ЮридическоеЛицо
    };
    dataContext.Save(counterparty);
    var контрагент2 = dataContext.Select<Контрагенты>().Single(x => x.Код == counterparty.Код);
    Assert.That(контрагент2.ИНН, Is.EqualTo("1234567890"));
Документы и справочники Generator.exe превращает в классы, а перечисления - в enum-ы языка C#. В примере выше для создания контрагента мы используем enum ЮридическоеФизическоеЛицо.
Абстрагируем ссылки, про них в прикладном коде можно просто забыть - создаем экемпляры классов объектной модели, присваиваем их свойствам других классов, при маппинге на соответствующие COM-объекты ссылки между ними будут проставлены автоматически.
    var контрагент = new Контрагенты
    {
        ИНН = "1234567890",
        Наименование = "test-counterparty",
        ЮридическоеФизическоеЛицо = ЮридическоеФизическоеЛицо.ЮридическоеЛицо
    };
    dataContext.Save(counterparty);
    var организация = dataContext.Select<Организация>().Single();
    var договор = new ДоговорыКонтрагентов
    {
        ВидДоговора = ВидыДоговоровКонтрагентов.СПокупателем,
        Наименование = "test name",
        Владелец = контрагент,
        Организация = организация
    };
    dataContext.Save(counterparty);
Метод Save сохраняет все объекты, до которых может добраться по ссылкам. Пример выше можно упростить следующим образом
 dataContext.Save(new ДоговорыКонтрагентов { ВидДоговора = ВидыДоговоровКонтрагентов.СПокупателем, Наименование = "test name", Владелец = new Контрагенты { ИНН = "1234567890", Наименование = "test-counterparty", ЮридическоеФизическоеЛицо = ЮридическоеФизическоеЛицо.ЮридическоеЛицо }, Организация = dataContext.Select<Организация>().Single() }); 
В запросах можно использовать стандартные Linq-операторы (Join, GroupBy пока не реализованы)
public decimal GetCurrencyRateToDate(string currencyCode, DateTime date)
{
    return dataContext.Select<КурсыВалют>()
        .Where(x => x.Валюта.Код == currencyCode)
        .Where(x => x.Период <= date)
        .OrderByDescending(x => x.Период)
        .First()
        .Курс;
}
Умеем обновлять отдельные строки табличных частей. Так, например, в таком примере
var поступлениеТоваровУслуг = new ПоступлениеТоваровУслуг
{
    Дата = new DateTime(2016, 6, 1),
    Контрагент = new Контрагенты
    {
        ИНН = "7711223344",
        Наименование = "ООО Тестовый контрагент",
    },
    Услуги = new List<ПоступлениеТоваровУслуг.ТабличнаяЧастьУслуги>
    {
        new ПоступлениеТоваровУслуг.ТабличнаяЧастьУслуги
        {
            Номенклатура = new Номенклатура
            {
                Наименование = "стрижка"
            },
            Количество = 10,
            Содержание = "стрижка с кудряшками"
        },
        new ПоступлениеТоваровУслуг.ТабличнаяЧастьУслуги
        {
            Номенклатура = new Номенклатура
            {
                Наименование = "стрижка усов"
            },
            Количество = 10,
            Содержание = "стрижка бороды"
        }                
    };
dataContext.Save(поступлениеТоваровУслуг);
var t = поступлениеТоваровУслуг.Услуги[0];
поступлениеТоваровУслуг.Услуги[0] = поступлениеТоваровУслуг.Услуги[1];
поступлениеТоваровУслуг.Услуги[1] = t;
dataContext.Save(поступлениеТоваровУслуг);

на втором вызове Save будет сгенерирован единственный вызов метода Сдвинуть, меняющий местами две строки.

Через метод DataContextFactory.CreateInMemory() можно получить inmemory-реализацию интерфейса IDataContext. Это здорово помогает при автоматизированном тестировании безнес-логики. Весь граф сервисных объектов поверх IDataContext можно создать целиком в inmemory-режиме, значительно ускорив этим прохождение тестов по сравнению с работой с настоящей 1С.

LINQ C# обмен

См. также

Медиадисплей. Рекламный информационный монитор для покупателя.

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

Монитор покупателя может отображать текущую покупку на кассовом месте, показывать видеорекламу, баннеры, во время простоя разворачивать рекламу на весь экран. Можно использовать в качестве графического меню-борда в кафе и видеовывески. Управление выводом на телевизор через hdmi-приставку на базе Windows или Android. В качестве устройства отображения можно использовать Android-планшеты, фоторамки с Android, монитор любого Windows-компьютера, доступного по сети. Настраивается ЛЮБОЙ ДИЗАЙН экрана!

16800 руб.

30.05.2017    52224    34    69    

43

Внешняя компонента для сканирования (замена TWAIN-компоненты БСП) (Native Win 32/64)

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

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

2400 руб.

12.05.2020    26409    132    99    

84

Внешняя компонента печати PDF (Native Win 32/64)

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

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

1500 руб.

17.09.2018    35236    106    127    

112

Внешняя компонента для подключения 1С к телефонии Asterisk

Разработка внешних компонент Телефония, SIP Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

Внешняя компонента выполнена по технологии Native API для 1С 8.х, обеспечивает доступ к программным АТС Asterisk (FreePBX, Elastix) через AMI интерфейс. Через него можно управлять многими функциями Asterisk (определение номеров, перевод звонков, набор телефона и т. д.)

2400 руб.

04.05.2018    45129    117    66    

61

Мастер создания внешних компонент 1С (технология COM) для DELPHI 6/7/8/2005/2006/2007/2008/2010/XE/XE2/XE3

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

Средство для сверхбыстрой разработки внешних компонент 1С:Предприятия 7.7 и 8 по технологии COM на всех версиях DELPHI, начиная с 6.

2000 руб.

28.03.2013    54060    35    14    

68

QR-код с логотипом компании (обычная и управляемая форма)

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

Как известно, стремление сделать свою рекламную продукцию запоминающейся и выделяющейся — верный путь к успеху. Сегодня, мы поговорим с вами о том, что можно сделать с обычным черно-белым QR-кодом, чтобы он стал более живым и привлекательным. Если вам не терпится попробовать сделать QR-код с логотипом компании, то эта обработка для вас!

2400 руб.

22.06.2016    30880    4    4    

8

Внешняя компонента 1С и С++. Продолжаем разговор.

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

А давайте запилим 8.3.26 до релиза, или оповещение с сервера...

19.02.2024    4168    starik-2005    28    

53

Внешние компоненты 1С и язык C++

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

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

26.01.2024    4926    starik-2005    32    

39
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. capitan 2472 25.06.16 10:20 Сейчас в теме
Есть проект 1С скрипт, на котором системные скрипты пишут на 1С и вот обратная история.
Это очень круто, но ради великих шняг, напишите хотя бы в комментариях - зачем ?
Быстрее, удобнее? Почему не из 1С ?
+
2. trustasia 14 30.03.19 13:17 Сейчас в теме
Посмотрел GIT, поддерживаю. Имею Андроид приложение, С++ сервер собирает с них данные, осталось положить их в 1С. Конфа нетиповая. Этот подход думаю пригодится.
+
3. acanta 30.03.19 14:45 Сейчас в теме
Насколько быстро происходит обмен с вызовом com объекта 1с из стороннего приложения?
+
Оставьте свое сообщение
88005555256
Заказать звонок
support@infostart.ru
Telegram
Чат на сайте