Работа с Excel через COM

01.10.18

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

Несколько примеров работы с excel (ms office 2010, в моем случае) через COM.

Выходной файл имеет вид:

Работа с файлом:

Excel = Новый COMОбъект("Excel.Application"); //подключение к Excel
Книга = Excel.WorkBooks.Add();  //добавление книги
Лист = Книга.Worksheets.add(); //добавление листа
Лист.Name = "ГЛАВНАЯ"; //имя листа (без проблелов)
Лист.Tab.ColorIndex = 3; //цвет ярлыка

(цвет брал с этой картинки что ниже, в терминалогии не силен что это за значения)

            

Excel.displayAlerts = 0; //отключить модальное окно Excel на перезапись файла
Книга.SaveAs(C:\excel.xlsx); //сохранения файла
Книга.Close(); //закрытие книги
Excel.Quit(); //закрытие COM

Заполнение файла:

Ячейка = Лист.Cells(2, 2); //получение ячейки в переменную
Ячейка.ColumnWidth = 70; //ширина полученной ячейки
Ячейка.RowHeight  = 100; //высота полученной ячейки
Ячейка.Borders.LineStyle = 1; //обводка ячейки         

 

//++ добавим изображение на лист
Верх = Ячейка.Top;
Лево = Ячейка.Left;
ВысотаКартинки = 100;
ШиринаКартинки = 372;
Лист.Shapes.AddPicture(C:\\image.png, Ложь, Истина, Лево, Верх, ШиринаКартинки, ВысотаКартинки); 
//-- добавим изображение на лист

 

Ячейка.Cells.Font.Size = 16; //размер шрифта          
Ячейка.Cells.Font.Bold = 1; //жирный шрифт
Ячейка.Cells.Font.Name = "Arial"; //наименование шрифта
Ячейка.HorizontalAlignment = -4108; //текст по центру
Ячейка.Columns.AutoFit(); //авот ширина ячейки
Ячейка.Cells.Interior.Color = 255; //цвет фона красный     
//.Color = 255 = ниже картинка

                                   

 

Ячейка.Value = "Текст"; //присвоить значение ячейки
Ячейка.Cells.Font.ColorIndex = 3; //цвет текста ячейки (см. выше таблиу цветов)
Ячейка.VerticalAlignment = 2; // Выровнять текст по центру (относительно верхнего края и нижнего).
Ячейка.HorizontalAlignment = 3; // Выровнять текст по середине (относительно левой границы ячейки и правой).
Ячейка.WrapText = 1; //перенос текста в ячейке
Ячейка.Hyperlinks.Add(Ячейка, https://url.com,"" , https://url.com ,  ); // ссылка в интернет
Ячейка.Hyperlinks.Add(Ячейка, "", ИмяЛиста+"!"+Ячейка.AddressLocal, Ячейка.Value,Ячейка.Value);//ссылка на ячейку в другом листе

//++ зафиксировать строку	
ТекКнига = Книга.WorkSheets(ИмяЛиста);	
Excel.ActiveWindow.SplitRow = 4;//Указываем строку по которую фиксируем шапку 
Excel.ActiveWindow.FreezePanes = 1;//Активизируем фиксацию 
//-- зафиксировать строку


 

Ячейка = Лист.Range(Лист.Cells(1,1),Лист.Cells(2,8));
Ячейка.Merge(); //объединение ячеек
Ячейка.RowHeight  = 60; //высота объединенной ячейки

 

//++ изображение со ссылкой на страницу
Верх = Ячейка.Top+3;
Лево = Ячейка.Left+145;
ВысотаКартинки = 55;
ШиринаКартинки = 140;           
Изображение = Лист.Shapes.AddPicture(C:\\image.png, Истина, Истина, Лево, Верх, ШиринаКартинки, ВысотаКартинки);
Лист.Hyperlinks.Add(Изображение, , "ГЛАВНАЯ!R1C");
//-- изображение со ссылкой на страницу

 

//Excel = COM Excel
//ИмяЛиста = (Строка) имя листа без пробелов
Функция ДобавитьЛистПоИмени(Excel, ИмяЛиста)

               НомерПоследнегоЛиста = Excel.WorkSheets.Count;
               ДобавленныйЛист = Excel.WorkSheets.Add(,Excel.WorkSheets(НомерПоследнегоЛиста));
               ДобавленныйЛист.Name = ИмяЛиста;
      
               Возврат ДобавленныйЛист; //добавленный новый лист с нужным именем
           
КонецФункции

//Excel = COM Excel
Процедура СкрытьЛистыПоУмолчанию(Excel)
          
               //скрыть листы по умолчанию (т.е. Лист1, Лист2, Лист3) - Excel сам автоматически добавляет эти листы
               КоличествоЛистов = Excel.ActiveWorkbook.Worksheets.Count;
               КоллекцияЛистов = Excel.ActiveWorkbook.Worksheets;

            
               Для ТекНомерЛиста = 1 По КоличествоЛистов  Цикл
                              ТекЛист = Excel.ActiveWorkbook.Worksheets(ТекНомерЛиста);
                              Если Найти(ТекЛист.Name, "Лист") <> 0 Тогда
                                            ТекЛист.Visible = False;
                              КонецЕсли;
               КонецЦикла;

КонецПроцедуры                        

 

См. также

Загрузка и выгрузка в 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 руб.

09.11.2016    241183    1107    906    

1035

Загрузка и выгрузка в 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    37580    402    68    

172

Загрузка и выгрузка в 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 форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 10.02.2025, версия 9.9 - 9.15)

16800 руб.

20.11.2015    158897    387    378    

517

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

4800 руб.

11.12.2019    59189    1012    3    

251

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

Кто получает документы в формате XML из различных сервисов ЭДО (формат 820 приказ ФНС 31 мая 2019) и набивает их вручную в 1С, тот наверняка хотел бы автоматизировать этот процесс. Поддержка конфигураций: Бухгалтерии 3, УПП 1.3, 1С:КА 2.4 и 1С:КА 2.5, УТ10, УТ11.4 и УТ11.5. Для бухгалтерии 3 добавлена поддержка формат 5.03 от 23/01/2025

3600 руб.

11.02.2020    94437    317    157    

231

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

458

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

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

4800 руб.

23.01.2022    11660    63    0    

40
Оставьте свое сообщение