Функция получения массива из Экселя

21.10.12

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

Функция, возвращающая содержимое эксель-файла в виде массива структур (работает в тонком клиенте и может результат передавать на сервер)

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

Текст функци:

Функция ПолучитьМассивИзЭкселя(Файл)
    Перем exl, ОписаниеСтруктуры, Данные;
    Данные=Новый Массив();
    exl= Новый COMОбъект("Excel.application");
    exl.Workbooks.Open(Файл);
    sh=exl.Workbooks(1).Worksheets(1);
    Столбец=1;
    ОписаниеСтруктуры="";
    Пока не sh.cells(1,Столбец).Value=Неопределено цикл
        ОписаниеСтруктуры=ОписаниеСтруктуры+СокрЛП(sh.cells(1,Столбец).Value)+",";
        Столбец=Столбец+1;
    КонецЦикла;
    ОписаниеСтруктуры=Лев(ОписаниеСтруктуры,СтрДлина(ОписаниеСтруктуры)-1);
    строка=2;
    Пока не sh.cells(строка,1).Value=Неопределено цикл
        нов = Новый Структура(ОписаниеСтруктуры);
        Столбец=1;
        Для Каждого поле из нов цикл
            нов[поле.Ключ]=sh.cells(строка,Столбец).Value;
            Столбец=Столбец+1;
        КонецЦикла;
        Данные.Добавить(нов);
        строка=строка+1;
    КонецЦикла;
    exl.Application.Quit();

    возврат Данные;
КонецФункции


Вступайте в нашу телеграмм-группу Инфостарт

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

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

См. также

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

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

5490 руб.

12.08.2021    45985    583    71    

219

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

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

12444 руб.

29.10.2014    232730    750    534    

498

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

Загружает данные из Акта приемки товара от ООО «Вайлдберриз», полученный из личного кабинета в формате *.xlsx или API в документ "Реализация (акты, накладные, УПД)" для конфигурации: Бухгалтерия предприятия, редакция 3.0, в документ "Реализация товаров и услуг" для Управление торговлей, редакция 11; Комплексная автоматизация 2; ERP 2 Управление предприятием и в документ "Расходная накладная" для Управление нашей фирмой 3.0; Розница 3.0

6100 руб.

24.01.2021    24926    122    0    

63

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

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

6100 руб.

01.03.2021    12531    71    0    

29
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. petrov_al 10 22.10.12 18:36 Сейчас в теме
Очень хорошо. Непробовали перенести таблицу экселя в 2-х мерный массив?
2. yermak 51 24.10.12 15:02 Сейчас в теме
Нет не пробовал - так как не вижу смысла, загрузку в структуру считаю более удобной для последующего использования
3. klel 24.10.12 22:35 Сейчас в теме
Интересно, попробуем =) Спасибо
4. PEHATA 5 23.01.15 16:01 Сейчас в теме
Для отправки сообщения требуется регистрация/авторизация