Вывод в 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 "); // ссылка в интернет

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

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

  • 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    45909    577    71    

218

Загрузка и выгрузка в 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    232622    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    24894    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    12516    71    0    

29
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
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 67 03.02.15 17:00 Сейчас в теме
Спасибо помогли примеры кодов
Для отправки сообщения требуется регистрация/авторизация