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

22.07.24

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

Внешняя обработка для создания запроса на основании табличных данных.

Скачать файл

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

Наименование SM По подписке [?]
В помощь разработчику: преобразование табличного документа в запрос:
.epf 13,25Kb
141
141
0 SM
Скачать

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

Набросал обработку для формирования запроса из табличного документа.

Порядок работы:

  • с помощью команды "Вывести список" формируем табличный документ (или любым другим способом, позволяющим это сделать)
  • копируем его или сохраняем
  • вставляем в обработку (или, соответственно, загружаем из файла)
  • колонки (имя и тип) заполнятся автоматически, при необходимости можно подкорректировать
  • выбираем количество помещаемых в запрос строк
  • выбираем имя временной таблицы (при необходимости) и способ объединения (ОБЪЕДИНИТЬ, ОБЪЕДИНИТЬ ВСЕ)
  • нажимаем "Преобразовать"

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

Текст запроса можно сразу проверить на корректность с помощью конструктора, распарсить на операторы и поля для визуальной проверки, сформировать код обработки.

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

Среда разработки: Windows 10x64, 1С:Предприятие 8.3 (8.3.24), обработка полностью универсальна для типовых конфигураций на базе БСП 3.1+.

Требования

  • Табличный документ в 1-й строке должен содержать имена колонок, данные начинаться со 2-й строки.
  • Имена колонок формируются с учетом правил образования имен переменных. При невозможности преобразовать имя выводится соответствующее уведомление.
  • В табличном документе не рекомендуется использовать команду Найти/Заменить, т.к. при каждом изменении перечитываются имена колонок, возможно зависание приложения.
  • Для использования доступны только примитивные типы, все остальные преобразуются к строке. Тип NULL преобразуется в значение NULL.

Код открыт, предложения по доработке приветствуются.

Проверено на следующих конфигурациях и релизах:

  • Зарплата и управление персоналом, редакция 3.1, релизы 3.1.30.15, 3.1.29.62
  • Бухгалтерия предприятия, редакция 3.0, релизы 3.0.153.21, 3.0.149.28

запросы

См. также

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

10000 руб.

02.09.2020    146704    805    392    

822

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

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

18000 руб.

06.10.2023    13079    34    7    

67

Инструментарий разработчика Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

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

9360 руб.

17.05.2024    17422    52    34    

98

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

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

300000 руб.

03.03.2021    13863    12    27    

36

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

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

10000 руб.

10.11.2023    8262    29    10    

53

SALE! %

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

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

4800 3840 руб.

14.01.2013    183983    1118    0    

891

Инструментарий разработчика Программист 8.3.14 1С:Конвертация данных Россия Платные (руб)

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

15000 руб.

07.10.2021    16349    5    25    

41

Инструментарий разработчика Чистка данных Свертка базы DevOps и автоматизация разработки Платформа 1С v8.3 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Поддерживаются управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя.

6900 руб.

20.08.2024    1665    3    0    

17
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. 300_po_vstrechke 1975 22.07.24 11:42 Сейчас в теме
Костылятор запросов)))
Если что, я лайкнул)
awk; leyburg; ixijixi; +3 Ответить
2. ixijixi 1896 22.07.24 11:50 Сейчас в теме
3. php5 25 22.07.24 16:08 Сейчас в теме
Лайк)) иногда бывает необходимость подобного рода деятельности, в копилку
Автору, большое спасибо.
Смело можно ставить, скачку за 1 стартмани)
maximus_2712; ixijixi; +2 Ответить
4. ixijixi 1896 22.07.24 16:43 Сейчас в теме
(3) Спасибо, Александр.

По поводу стартмани мое ИМХО в том, что инструменты, облегчающие разработчику жизнь, внутри коммьюнити надо стараться распространять бесплатно.
Рамзес; JOJ73; Good_Smile; echo77; alisakish; flanchev; 0x00; leyburg; user1866668; hep-cat; 300_po_vstrechke; +11 Ответить
5. PerlAmutor 130 23.07.24 05:48 Сейчас в теме
Покажу как тоже самое сделать через Инструменты Разработчика

https://www.youtube.com/watch?v=jtCH9ovy1BQ
Прикрепленные файлы:
2024-07-23 05-46-44.mp4
kuzyara; DoctorRoza; Armando; 300_po_vstrechke; fancy; +5 Ответить
6. SerVer1C 786 23.07.24 12:30 Сейчас в теме
9. ixijixi 1896 23.07.24 15:02 Сейчас в теме
(6) Ёлки, а ведь я ее видел, даже в комментах отметился) А когда понадобилось - забыл...
10. echo77 1870 25.07.24 11:03 Сейчас в теме
(6) Было да (это мое) - но она не умеет только в примитивные типы
7. SerVer1C 786 23.07.24 12:33 Сейчас в теме
Кстати, на скрине видно "ОБЪЕДИНИТЬ". Почему не "ОБЪЕДИНИТЬ ВСЕ" ?
8. ixijixi 1896 23.07.24 15:00 Сейчас в теме
(7) Справедливо. Добавил в форму выбор способа объединения. Плюс возможность указать имя временной таблицы при необходимости.
Прикрепленные файлы:
skif-m; 0x00; +2 Ответить
Оставьте свое сообщение