Генерация кода с помощью формул Excel

27.10.20

Интеграция - Загрузка и выгрузка в Excel

В работе периодически возникает необходимость создания однотипных строк кода, отличающихся, в общем случае, только неким известным заранее строковым содержимым. При помощи конкатенации в Excel подобные данные легко превратить в готовые строки кода.

Например, у нас есть известные области макета и мы зачем-то хотим поместить их в структуру или соответствие.
Имена областей:

"Шапка|Артикул"
"Шапка|Наименование"
"Шапка|Количество"
"Строка|Артикул"
"Строка|Наименование"
"Строка|Количество"
"Итоги|Артикул"
"Итоги|Наименование"
"Итоги|Количество"

Копируем эти строки и вставляем в Excel.
При вставке в Excel кавычки будут удалены. Это не должно смущать, т.к. это не имеет значения для решения задачи.
В соседний столбец вводим формулу и протягиваем её до конца значений в первом столбце:

="ИмяСтруктуры.Вставить("""&A1&""", Макет.ПолучитьОбласть("""&A1&"""));"

На выходе получаем строки:

ИмяСтруктуры.Вставить("Шапка|Артикул", Макет.ПолучитьОбласть("Шапка|Артикул"));
ИмяСтруктуры.Вставить("Шапка|Наименование", Макет.ПолучитьОбласть("Шапка|Наименование"));
ИмяСтруктуры.Вставить("Шапка|Количество", Макет.ПолучитьОбласть("Шапка|Количество"));
ИмяСтруктуры.Вставить("Строка|Артикул", Макет.ПолучитьОбласть("Строка|Артикул"));
ИмяСтруктуры.Вставить("Строка|Наименование", Макет.ПолучитьОбласть("Строка|Наименование"));
ИмяСтруктуры.Вставить("Строка|Количество", Макет.ПолучитьОбласть("Строка|Количество"));
ИмяСтруктуры.Вставить("Итоги|Артикул", Макет.ПолучитьОбласть("Итоги|Артикул"));
ИмяСтруктуры.Вставить("Итоги|Наименование", Макет.ПолучитьОбласть("Итоги|Наименование"));
ИмяСтруктуры.Вставить("Итоги|Количество", Макет.ПолучитьОбласть("Итоги|Количество"));

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

Процедура ДобавитьЭлементКоллекции(Коллекция, Знач Ключ)
    Коллекция.Вставить(Ключ, Макет.ПолучитьОбласть(Ключ));
КонецПроцедуры

В таком случае формула бы выглядела вот так:

="ДобавитьЭлементКоллекции(ИмяСтруктуры, """&A1&"""));"

А результат так:

ДобавитьЭлементКоллекции(ИмяСтруктуры, "Шапка|Артикул"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Шапка|Наименование"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Шапка|Количество"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Строка|Артикул"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Строка|Наименование"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Строка|Количество"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Итоги|Артикул"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Итоги|Наименование"));
ДобавитьЭлементКоллекции(ИмяСтруктуры, "Итоги|Количество"));

Один мой коллега сказал, что подобным образом генерирует строки для SQL-запросов, то есть идея оригинальностью не блещет. Скорее, это сам по себе напрашивающийся подход в условиях рутинного ввода однотипных строк.


Но если вдруг вы ещё не пользовались подобным способом, уверяю, он может сэкономить вам массу времени, особенно когда данных не 9 строк, как в примере, а несколько десятков (надеюсь, сотни однотипных строк никому вводить не приходится).

лайфхак Excel кодогенерация

См. также

Загрузка номенклатуры из Excel в УТ11, КА 2, ERP 2, Розница 2. Дополнительные реквизиты и сведения, характеристики, картинки, цены, остатки

Загрузка и выгрузка в Excel Розничная торговля Логистика, склад и ТМЦ Ценообразование, анализ цен Прайсы Платформа 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Розница 2 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Управленческий учет Платные (руб)

Загрузка из файлов xls, xlsx, ods, csv, mxl в УТ11, КА 2, ERP 2, Розница 2. Задействованы все возможности конфигурации - заполнение реквизитов номенклатуры, дополнительных реквизитов и сведений, характеристики, доп.реквизиты и сведения характеристик. Дополнительные обработки для расширения возможностей.

10560 руб.

29.10.2014    211083    630    526    

446

Загрузка номенклатуры c картинками (несколько потоков одновременно) и сопутствующими данными в базу и любые документы из yml, xls, xlsx, xlsm, ods, ots, csv для УТ 10.3, УТ 11 (все), БП 3, КА 2, ERP 2, УНФ 1.6/3.0, Розница 2

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

Эволюция не стоит на месте - новая удобная версия функциональной обработки для Вашего бизнеса! Что же Вы получаете? Удобный и интуитивно понятный интерфейс с 3-мя этапами работы. 2 режима - автоматический и ручной. Чтение XLSX, XLSM, CSV, XML/YML форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 09.04.2024, версия 9.9 - 9.10)

14400 руб.

20.11.2015    151352    367    376    

502

Маркетплейсный загрузчик для 12-ти маркетплейсов в 1С:БП 3, УТ 11, КА 2, ERP, УНФ

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

Реальный помощник, с помощью которого Вы сделаете необходимые документы для Wildberries, OZON, ЯндексМаркет, Мегамаркет, Aliexpress, "Детский мир", Казань-Экспресс, "Леруа Мерлен", ЭНФАНТА (Акушерство), ЛаМода, Летуаль, "Твой дом" в документы "Отчет комиссионера (агента) о продажах" и другие, может работать в "Бухгалтерия 3", "Бухгалтерия 3 КОРП", УТ 11, УНФ, КА 2, ERP. Возможность подключить любые маркетплейсы. Анализ продаж ОЗОН. 30 дней БЕСПЛАТНОГО пользования!

1800 руб.

12.08.2021    32282    240    64    

122

SALE! 30%

Распознавание и загрузка сканов в 1С "одним нажатием": УПД, ТОРГ-12, накладные, счета, номенклатура, заказы и т.д.

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

Универсальная программа для распознавания ЛЮБЫХ СКАНОВ ИЛИ ФОТО ТОВАРНЫХ ДОКУМЕНТОВ в 1С. Не требует указания параметров и предварительной настройки. Просто выбираете файл (PDF, JPG, DOC, XLS, HTML и т.д.) выбираете документ 1С и нажимаете кнопку "Распознать и загрузить".

6000 5520 руб.

04.06.2019    101805    298    173    

314

Загрузка данных отчета о реализации товаров из Excel файла СберМегаМаркет

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

Загрузка данных отчета о реализации товаров из сервиса СберМегаМаркет для конфигурации: Бухгалтерия предприятия, редакция 3.0; Управление торговлей, редакция 11 и Управление нашей фирмой, редакция 3.0 в документ "Отчет комиссионера (агента) о продажах".

4800 руб.

07.06.2022    15360    82    0    

63

SALE! 20%

Загрузка документов и номенклатуры из Excel в 1С "одним нажатием": УПД, ТОРГ-12, отчеты маркетплейсов, заказы, счета, прайсы

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

Универсальная обработка для загрузки документов из Excel в 1С. Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл Excel, документ 1С и нажимаете кнопку "Загрузить". Обработка сама находит таблицу в файле Excel, необходимые для загрузки данные в ней (номенклатура, количество, НДС, цена, сумма) и загружает ее в 1С. Вместе с номенклатурой может найти контрагента, номер и дату документа, штрих-коды, серии ГТД, страну и т.д. Распознает документы ЛЮБОЙ ФОРМЫ (УПД, ТОРГ-12, заказ, отчет комиссионера и т.д.). Не требует MS Office. Для поиска таблиц используются методы эвристического поиска. Загружает только то, что нужно, т.е. пропускает повторы шапки таблицы, заголовки, промежуточные итоги, подписи и т.д. Содержит модуль работы с электронной почтой и api-загрузчик отчетов о продажах маркетплейсов.

5000 4000 руб.

09.11.2016    215791    928    886    

942
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. milkers 2871 27.10.20 10:42 Сейчас в теме
Гораздо проще этот текст вставить в макет, а потом перебирая строки макета вызвать в цикле
ИмяСтруктуры.Вставить(СтрокаИзМакета, Макет.ПолучитьОбласть(СтрокаИзМакета));

И меньше кода и проще редактировать.
work.sable; +1
3. AlekseiAdamov 166 27.10.20 13:42 Сейчас в теме
(1) Описанный Вами подход либо для труъ-1Сника, либо для ситуаций, когда известные значения используются постоянно в коде, а не для разовых задач.
+
2. пользователь 27.10.20 11:13
Сообщение было скрыто модератором.
...
4. milkers 2871 27.10.20 14:02 Сейчас в теме
(3) И чем это не подойдет для разовой задачи? :)
+
5. AlekseiAdamov 166 27.10.20 16:46 Сейчас в теме
(4) В фразе
Например, у нас есть известные области макета и мы зачем-то хотим поместить их в структуру или соответствие

ключевым словом является "Например". Речь не только и не столько о работе с областями макета.
Задача не в том, чтобы заполнить коллекцию, а в том, чтобы получить готовые строки.
Да и зачем создавать макет для разовой задачи? Макет не существует сам по себе - это либо общий макет, либо макет объекта. Тогда уж проще сохранить текстовый или табличный файл и из него прочитать значения. Или парсить текст из буфера обмена.
Использование Excel избавляет от всего этого, даже файл сохранять не надо - сгенерировали строки и закрыли без сохранения.
Не каждая задача требует написания отдельной обработки.
+
6. milkers 2871 27.10.20 17:26 Сейчас в теме
Если Вы собираетесь громоздить простыню однотипного кода, то явно она существует не просто так, а в привязке к какому нибудь объекту: Обработке, справочнику и т.д. Рекомендую разместить в этом объекте макет . Не желаете использовать макет - используйте текстовую строку с переносами и превращайте ее в массив через СтрРазделить(<Строка>, <Разделитель>, <ВключатьПустые>) . В любом случае вы получите на выходе более красивый код и сильно сэкономите время. Подогнать формулу в Экселе явно не пять минут.
+
7. AlekseiAdamov 166 27.10.20 18:22 Сейчас в теме
(6)
В любом случае вы получите на выходе более красивый код и сильно сэкономите время. Подогнать формулу в Экселе явно не пять минут

Насчёт красивого кода согласен (когда использование макетов оправдано), насчёт экономии времени нет - эти формулы требуют меньше 1 минуты, затраты времени только на ввод символов, ну или если с количеством кавычек ошиблись.
Опять же, по поводу использования макета: что делать, если разработка не на платформе 1С, а на чём-то другом, где нет объектов, подобных табличному макету в 1С?
Предложенный подход универсален тем, что его можно использовать для любого языка - хоть 1С, хоть 1C:Эксплуататор, хоть OneScript, хоть Java, хоть VB - да и не только в программировании, а просто для целей массового преобразования строк.
+
Оставьте свое сообщение