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

22.06.16

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

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

Файлы

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

Наименование Скачано Купить файл
simple1c.zip
.zip 370,54Kb
2 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Вы можете заказать платную доработку или адаптацию этой разработки под вашу конфигурацию на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.
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С:Предприятие 8 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Розничная и сетевая торговля (FMCG) Рестораны, кафе и фаст-фуд Реклама, PR и маркетинг Управленческий учет Платные (руб)

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

18300 руб.

30.05.2017    57089    11    71    

48

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

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

5084 руб.

17.09.2018    41302    118    128    

120

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

В современных корпоративных решениях на платформе 1С:Предприятие 8.3 всё чаще возникает потребность в визуальном моделировании и автоматизации бизнес-процессов с использованием нотации BPMN 2.0. Стандартные средства платформы не предоставляют полноценного редактора BPMN, однако интеграция открытой библиотеки bpmn-js позволяет реализовать интерактивное моделирование бизнес-процессов непосредственно в 1С. В статье рассмотрены архитектура решения, пошаговая инструкция по сборке библиотеки из исходников для WebKit, а также примеры программного взаимодействия между 1С и JavaScript.

03.04.2026    2275    SultanovStas    8    

21

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

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

14.01.2025    6864    bayselonarrend    17    

54

Разработка внешних компонент Программист 1С:Предприятие 8 Россия Бесплатно (free)

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

04.12.2024    11841    kovalevdmv    29    

83

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

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

26.01.2024    12084    starik-2005    40    

49
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. capitan 2575 25.06.16 10:20 Сейчас в теме
Есть проект 1С скрипт, на котором системные скрипты пишут на 1С и вот обратная история.
Это очень круто, но ради великих шняг, напишите хотя бы в комментариях - зачем ?
Быстрее, удобнее? Почему не из 1С ?
4. native-api 30 02.06.25 11:07 Сейчас в теме
(1) Зачем писать на морально устаревшем языке, если можно писать на современном, куда более мощном, удобном, масштабируемом, поддерживаемом различными инструментами? Я, наоборот, не понимаю тех, кому пришло в голову писать на языке 1С за пределами 1С. Язык 1С настолько морально устарел и полон анти-паттернами по сравнению с Питоном, C#, даже современными версиями PHP, что нужно быть мазохистом или совсем узколобым и ограниченным человеком (который не знает и знать не желает ничего другого), чтобы писать на нем добровольно, зря теряя собственное время и нервы.
2. trustasia 14 30.03.19 13:17 Сейчас в теме
Посмотрел GIT, поддерживаю. Имею Андроид приложение, С++ сервер собирает с них данные, осталось положить их в 1С. Конфа нетиповая. Этот подход думаю пригодится.
3. acanta 30.03.19 14:45 Сейчас в теме
Насколько быстро происходит обмен с вызовом com объекта 1с из стороннего приложения?
Для отправки сообщения требуется регистрация/авторизация