Универсальная таблица для ввода данных

01.09.14

Разработка - Инструментарий разработчика

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

Я хочу рассказать о том, как я в своё время решил эту задачу.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Пример (выгрузка ИБ)
.dt 42,45Kb
4
4 Скачать (1 SM) Купить за 1 850 руб.
Время от времени к программисту обращаются пользователи с просьбой перенести некую эксельку в 1С.
Это может быть что угодно - какой-то отчет, заполняемый менеджерами, список клиентов (доморощенный аналог CRM), таблица состояния товара в пути.
Эти данные могут выгружаться из какой-то удаленной учетной системы, либо вводиться вручную.

Я хочу рассказать о том, как я в своё время решил эту задачу.

Для себя я формализовал условия следующим образом:
1. Необходима возможность хранения произвольных данных в виде прямоугольных таблиц
2. Поля таблиц должны быть типизируемыми
3. Все данные, которые уже есть в ИБ, должны браться именно оттуда (то есть, всё что можно выбираем из справочников и документов)
4. Нужна поддержка одновременной работы в таблице нескольких пользователей

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

ЗначенияПолей
    Измерения
        Поле (СправочникСсылка.ОписаниеПолей),
        НомерСтрокиТаблицы (Число)
    Ресурсы
        Значение (ЛюбаяСсылка, Булево, Строка, Дата, Число)
        
Для того, чтобы можно было оперативно узнать автора последнего изменения, можно еще добавить ресурс Пользователь - я в своем примере добавил.
Правда, так как у меня справочника пользователи нет, тип реквизита - Строка.
Остановлюсь подробнее на  справочнике ОписаниеПолей: тут наверное больше бы подошел план видов характеристик, но исторически так сложилось,
что это спроавочник. Он хранит заголовки и типы полей, а так же произвольную информацию для настройки:

ОписаниеПолей
    Реквизиты
        ИмяПоля
        НомерПоПорядку
        ТипДанных
        Ширина
        
У меня реквизит Ширина содержит ширину ячейки. Можно хранить еще например цвет или шрифт - просто для красоты. Справочник двухуровневый, группы
справочника соответсвуют разным таблицам - хотя можно сделать отдельный справочник таблиц, я не сделал потому что у меня не было необходимости
хранить какие-то настройки таблиц, только названия.

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

Для реализации пункта 4 я создал еще один регистр сведений, который хранит блокировки. То есть, когда пользователь входит в режим редактирования ячейки,
в регистр вносится соответсвующая запись. У меня структура получилась такая:

БлокировкиПолей
    Измерения
        Поле
        НомерСтрокиТаблицы
    Ресурсы
        Дата
        Пользователь
        Сеанс
        
Теперь если мы попытаемся отредактировать ячейку, в которой уже кто-то сидит, мы получим сообщение об ошибке с описанием когда и кто начал её редактировать.
Блокировка делается одинаково как на уровне ячейки, так и на уровне строки. В моём примере сделана блокировка на уровне строки, чтобы переделать её на блокировку
отдельных ячеек достаточно записывать в регистр описание поля, а не описание таблицы, как у меня:
...
Запись.Поле = ИмяТаблицы;
...

Вот собственно и всё. Получился "остов", которым в принципе можно пользоваться в том виде, в котором он есть. На практике полезно добавить
разделение прав пользователей на таблицы и поля - чтобы например смотреть могли все, а редактировать только некоторые. В моём примере этого нет,
но вообще приходилось делать. Отдельно идет возможность загружать данные из внешних источников - вещь специфическая, её не обобщишь.

Что интересно, я такую статью уже писал, но в тот же день Инфостарт откатило и она исчезла, а копию я не сохранил. Надеюсь в этот раз повезет больше )

ввод данных excel таблица

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

12000 руб.

02.09.2020    171978    964    403    

924

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

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14471    109    46    

108

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

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

22200 руб.

06.10.2023    17331    43    15    

75

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

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    27333    96    48    

138

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

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

15000 руб.

10.11.2023    11936    45    33    

67

SALE! %

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

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

4800 3840 руб.

14.01.2013    191317    1153    0    

920

Инструментарий разработчика Программист 8.3.14 Россия Платные (руб)

Расширение для конфигурации “Конвертация данных 3”. Добавляет подсветку синтаксиса, детальную контекстную подсказку, глобальный поиск по коду.

20000 руб.

07.10.2021    18107    7    32    

42

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

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

3600 руб.

27.12.2024    1143    2    0    

5
Оставьте свое сообщение