Вывод в Excel через COM

28.03.10

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

Была задача, создать через Excel файл, через COM, оформленный «красиво».

Выкладываю примеры кода.

Начнем с простого - создадим СОM-Объект.
Пример функции создания:

// функция устанавливает связь с EXCEL
Функция EXCELСоздатьCOMОбъект() Экспорт

   
Excel = Неопределено;

   
# Если клиент тогда
       
Состояние("Идет установка связи с в Excel ");
   
# КонецЕсли

   
Попытка
       
Excel = Новый COMОбъект("Excel.Application");
    Исключение
       
# Если клиент тогда
           
Сообщить("Ошибка создания обьекта Microsoft Excel" + ОписаниеОшибки(), СтатусСообщения.Внимание);
       
# КонецЕсли
   
КонецПопытки;

    Возврат
Excel;
КонецФункции
//EXCELСоздатьCOMОбъект

Теперь создаем или открываем файл.

ФайлExcel = Excel.Documents.Open("С:\MyExcelFile.xls").

Пример функции создания файла из шаблона.

Функция EXCELОткрытьШаблон(Excel, ИмяФайла) Экспорт

   
ФайлExcel = Неопределено;

    # Если клиент тогда
      
Состояние("Идет открытие файла " + ИмяФайла + " , ждите....." );
   
# КонецЕсли

   
Попытка
       
ФайлEXCEL = Excel.WorkBooks.Add(ИмяФайла);
    Исключение
       
# Если клиент тогда
           
Сообщить("Ошибка создания обьекта Microsoft Excel" + ОписаниеОшибки(), СтатусСообщения.Внимание);
       
# КонецЕсли
   
КонецПопытки;


    Возврат
ФайлExcel;

КонецФункции //EXCELОткрытьШаблон

Получим лист файла Excel

ЛистДанных = ФайлEXCEL.Worksheets(1);
ЛистСодержание = ФайлEXCEL.Worksheets(2);
ЛистДанных.Name = Формат(ТекущаяДата(),"ДФ='dd.MM.yyyy ЧЧ мм'"); //Задаем имя листу

Теперь перейдем к работе с ячейками и диапазоном ячеек.

Ячейка = Cells(НомерСтроки, НомерКолонки) // Получим ячейку
ДиапазонЯчеек = ЛистДанных.Range(ЛистДанных.Cells.Item(НомерСтроки, НомерКолонки), ЛистДанных.Cells.Item(НомерСтроки +1 , НомерКолонки +1) //Получим диапазон ячеек
Ячейка.Value = «Задаем значение в ячейке» // Задаем значение в ячейке

Форматирование ячеек или диапазона ячеек.
Лучше форматировать диапазон ячеек, будет быстрее. Чтобы получить нужный результат создаешь макрос, форматируешь ячейку, смотришь код в макроса.
Значение констант например xlTop, xlToRight из EXCEL. В EXCEL есть VBA - alt+F11 и в нем Object Browser - F2 и в нем поиск.

Ячейка.Font.Size = 12;// Устанавливаем размер шрифта
Ячейка.Font.Name = "Century Gothic"; //Устанавливаем шрифт
Ячейка.Font.ColorIndex = 5;// Устанавливаем цвет
Ячейка.Font.Bold = Истина; // Устанавливаем жирный шрифт
Ячейка.Borders(5).LineStyle = -4142; // Очищаем все границы
Ячейка.Borders(1).LineStyle = 1; // Устанавливаем левую границу
Ячейка.Borders(8).LineStyle = 1; // Устанавливаем верхнюю границу
Ячейка.Borders(9).LineStyle = 1; // Устанавливаем нижнюю границу
Ячейка.Borders(10).LineStyle = 1; // Устанавливаем правую границу
Ячейка.Interior.Color = RGB(51, 153, 102); //цвет фона
Ячейка.HorizontalAlignment = -4131; //Горизонтальное выравнивание текста 4131 -лево 4108 центр -4152 право
Ячейка.VerticalAlignment = -4107; //Вертикальное выравнивание текста
Ячейка.IndentLevel = 6; //Отступ
Ячейка.Merge(Истина); //Объединение ячеек

Создание ссылки 

Лист.Hyperlinks.Add(ДиапазонЯчеек, "", «ИмяОбласти», Гиперссылка, Гиперссылка); // ссылка на именованную область
ЛистExcel.Hyperlinks.add(ЛистExcel.cells(1,1),"","Лист3!A1","","моя ссылка") // ссылка на ячейку
Ячейка.Hyperlinks.Add(Ячейка, //infostart.ru,"" , "infostart.ru " , "infostart.ru "); // ссылка в интернет

См. также

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

8000 руб.

09.11.2016    247105    1136    913    

1058

Загрузка и выгрузка в Excel Маркетплейсы Программист Бухгалтер Пользователь Платформа 1С v8.3 Бухгалтерский учет 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С:КА 2, 1С:ERP Управление предприятием. Возможность подключить любые маркетплейсы. Анализ продаж ОZON. 30 дней БЕСПЛАТНОГО пользования!

5400 руб.

12.08.2021    39064    431    68    

178

Загрузка и выгрузка в 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.04.2025, версия 9.10 - 10.0)

18000 руб.

20.11.2015    161205    398    386    

525

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

Загрузка данных отчета о реализации и продаже товаров из сервиса Яндекс.Маркета «Беру» из отчетов Excel для конфигурации: Бухгалтерия предприятия, редакция 3.0; Управление торговлей, редакция 11; Управление торговлей, редакция 10.3; Управление нашей фирмой, редакция 3.0 и Розница, редакция 3.0 в документ «Отчет комиссионера о продажах».

6000 руб.

09.12.2020    27336    281    1    

135

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

Обработки загрузки данных о продажах WildBerries предназначены для следующих конфигураций: Бухгалтерия предприятия, редакция 3.0; Управление нашей фирмой, редакция 3.0; Розница, редакция 3.0; Управление торговлей, редакция 11; Управление торговлей, редакция 10.3

6000 руб.

11.12.2019    60098    1029    3    

264

Загрузка и выгрузка в 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    219629    675    529    

462
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. eeeio 127 04.11.10 10:30 Сейчас в теме
спасибо. скопировал - и думать не пришлось! плюс.
2. Bober777 26 08.01.12 15:19 Сейчас в теме
Красота это хорошо а можно пример получить с группировками?
3. MrVesna 20 19.03.12 17:56 Сейчас в теме
Обязательно надо скопировать. Лучше будет для начинающих если еще приведешь примеры с рисунками, хотя и так все понятно. Спасибо!
4. need1cc 20.03.12 11:21 Сейчас в теме
5. need1cc 20.03.12 11:21 Сейчас в теме
а все спасибо, разобрлся
6. ZLENKO 398 26.03.12 13:28 Сейчас в теме
В Excel 2007-2010 жутко тормозит работа с ячейками :-(
7. ZLENKO 398 19.04.12 11:39 Сейчас в теме
Проблему с "тормозами" в Excel 2007-2010 решил через программную эмуляцию действий КАНТРЭЛ-ЦЭ и КАНТРЭЛ-ВЭ.
Формирую текстовый файл, который надо вывести в Excel (можно вставлять формулы), запихиваю его в буфер обмена и выполняю Paste в предварительно подготовленый лист-макет Excel. Нашел 8 различных способов вывода данных в Excel, но этот мне подошел больше всего т.к. с одной стороны обеспечивает высокую скорость, а с другой позволяет работать с оформлением на листе и использовать заготовки-макеты.
8. Ele1234567 11.04.14 14:10 Сейчас в теме
Спасибо, будемс смотреть и пробовать.
9. buval 66 03.02.15 17:00 Сейчас в теме
Спасибо помогли примеры кодов
Оставьте свое сообщение