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

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();

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


См. также

SALE! 20%

Загрузка и выгрузка в Excel Оптовая торговля Печатные формы Бухгалтер Пользователь Платформа 1С v8.3 Управляемые формы Платформа 1C v8.2 1C:Бухгалтерия 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С:Розница 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Универсальная обработка для загрузки документов из Excel в 1С. Забудьте о ручном вводе: загружайте документы из Excel в 1С за секунды! Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл Excel, документ 1С и нажимаете кнопку "Загрузить". Обработка сама находит таблицу в файле Excel, необходимые для загрузки данные в ней (номенклатура, количество, НДС, цена, сумма) и загружает ее в 1С.

6000 5100 руб.

09.11.2016    238683    1086    905    

1021

Загрузка и выгрузка в 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 1С:Розница 3.0 Платные (руб)

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

16800 руб.

20.11.2015    157699    384    378    

516

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

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

4800 руб.

23.01.2022    11497    61    0    

39

SALE! 30%

Загрузка и выгрузка в 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С и нажимаете кнопку "Распознать и загрузить".

8400 5880 руб.

04.06.2019    108602    317    173    

328

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

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

11100 руб.

29.10.2014    217749    662    529    

457

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

Расширение позволяет гибко настроить выгрузку индивидуальных цен и остатков (товарный фид) в пользовательском режиме по соглашениям с клиентами. Поддерживается выгрузка в файлы XML в формате Яндекс.Маркет (YML) автоматически по расписанию в каталог на диске или на FTP-сервер.

18000 руб.

15.08.2024    639    2    0    

2
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
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 Сейчас в теме
Оставьте свое сообщение