Сохранение картинки из MS Excel в файл без использования внешних компонент

27.05.13

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

Казалось бы, чего может быть проще, чем выгрузить картинку из excel: найди объект картинки, у объекта найди метод Save или Export или что-нибудь подобное, но не сложнее того.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
ExportPicturesFromExcel.cf
.cf 11,64Kb
36
36 Скачать (1 SM) Купить за 1 850 руб.

Простого пути не нашел, пришлось идти окольными путями.

Конечно же, сначала в интернет... обнаружил, что люди сталкиваются с теми же проблемами, что и я.


Немного об объектной модели Excel.


1. Приложение: Application. Приложение мы создаем так:

    Application = Новый COMОбъект("Excel.Application");

 

2. Приложение имеет колекцию книг: Application.Workbooks.

Файл эксель открывается как книга Workbook, т.е. элемент коллекции Workbooks, например,

    Workbook = Application.Workbooks.Item(0);

или когда хотим открыть файл-excel

    Workbook = Application.Workbooks.Open(ПутьКФайлу);

 

3. Коллекция листов и диаграмм Workbook.Sheets,

можно и по отдельности обойти коллекцию листов Workbook.Worksheets и коллекцию диаграмм Workbooks.Charts, а можно одним махом через коллекцию Sheets.

Каждый элемент этой коллекции (лист или диаграмма) имеют свойство  Shapes с коллекцией объектов Shape, дословно "фигура".

 

4. Коллекция фигур Sheet.Shapes содержит коллекцию различных графических объектов листа или диаграммы.

В числе этих графических объектов можно найти и картинку.

 

5. Картинка. Каждый элемент Shape коллекции Shapes имеет свойство Shape.Type, которое принимает значения перечисления MsoShapeType. Одно из значений этого перечислений MsoShapeType.msoPicture = 13. То, что нужно.

Таким образом мы можем найти все объекты картинок в любом файле MS Excel, и это не сложно. 


6. Картинку в файл. А вот, что делать каждым объектом Shape, чтобы его выгрузить в файл - это уже вопрос.

Методов у фигуры Shape много. Единственный, хоть как-то касающийся вопроса, это метод CopyPicture, при вызове этого метода картинка копируется в буфер обмена. От чего легче не становится.

Встает другой вопрос, как достать из буфера картинку, или переложить в другой объект Excel, где есть нужные методы.

Можно было бы экспортировать лист с нужной картинкой в HTML документ, а затем в папке документа html *.files поискать картинки. Сумбурный метод.

Оказывается, удобней из буфера переложить картинку в объект диаграммы Chart, при этом подогнав размеры диаграммы под картинку, а диаграмму можно аккурат сохранить как картинку в нужный файлик. Это уже порядок.

Всем этим занимается следующая функция. Даём ей объект Shape, ИмяФайла и ТипФайла:

//  Сохранение картинки из объекта Shape в файл.
//      FilterName - строка, JPG, GIF, PNG, BMP и т.д.
Функция СохранитьКартинкуВФайл(Shape, FileName, FilterName = Неопределено) Экспорт

   
//  Инициализируем константы VBA.
   
msoFalse = 0;
   
msoPicture = 13;
   
xlLineStyleNone = -4142;
   
xlWBATWorksheet = -4167;

   
//  Проверяем тип объекта.
   
Если Shape.Type <> msoPicture Тогда
        Возврат Ложь;
    КонецЕсли;

   
//  Создаем новую книгу с единственным листом.
   
Книга = Shape.Application.Workbooks.Add(xlWBATWorksheet);

   
//  Создаем диаграмму, в которую копируем картинку.
   
Диаграмма = Книга.Worksheets.Item(1).Shapes.AddChart().Chart;

   
//  Устанавливаем размер диаграммы как у картинки.
   
Диаграмма.ChartArea.Height = Shape.Height;
   
Диаграмма.ChartArea.Width = Shape.Width;

   
//  Убираем границу диаграммы.
   
Диаграмма.ChartArea.Border.LineStyle = xlLineStyleNone;

   
//  Убираем заполнение диаграммы.
   
Диаграмма.ChartArea.Fill.Visible = msoFalse;

   
//  Копируем картинку в буфер.
   
Shape.CopyPicture();

   
//  Вставляем данные в диаграмму из буфера.
   
Диаграмма.Paste();

   
//  Экспортируем диаграмму в картинку (*.jpg, *.gif, *.bmp, *.png).
   
Успех = Диаграмма.Export(FileName, FilterName);

   
//  Закрываем книгу без сохранения изменений.
   
Книга.Close(False);

    Возврат
Успех;

КонецФункции

 

Во вложении конфигурация с примером использования функции.

См. также

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

256

SALE! 30%

ЭДО и ОФД Загрузка и выгрузка в 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    94966    321    157    

232

Загрузка и выгрузка в Excel Бухгалтер Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Создание документов реализации услуг, автоматическое создание контрагентов, договоров по данным, указанным в Excel.

3600 руб.

06.05.2020    11037    30    18    

10

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

Задача быстро перейти с Управления торговлей 10.3 или Управление производственным предприятием 1.3 или Бухгалтерия предприятия 2.0 на Управление торговлей 11.4, 11.5 или Управление предприятием ERP 2.4, 2.5 Но, у Вас ну очень старый релиз. Да и он очень, очень переписанный разными программистами 1С. И Вам не хочется его обновлять до нужного. Тогда это решение именно для Вас. Время перехода занимает от 10-30 минут.

4800 руб.

24.12.2019    23568    24    0    

26

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

Обработка создания файла по стандарту обмена с системами "Клиент банка" kl_to_1c.txt Формат файла обмена Российская Федерация, версия 1.03 При восстановлении учета в случае отсутствия в 1с банковских выписок (например, р/с в банке закрыт в связи с банкротством и доступ к выгрузке из клиент-банка невозможен), можно запросить у банка выписку за период в формате Excel. С помощью этой обработки создается файл формата 1CClientBankExchange, в 1с77 он назывался kl_to_1c.txt который загружается штатными средствами в 1с8. При этом будут созданы загружаемые контрагенты и их р/с.

4320 руб.

19.04.2019    45444    155    54    

90

Пакетная печать ККМ Кассовые операции Загрузка и выгрузка в Excel Бухгалтер Пользователь Россия Бухгалтерский учет Платные (руб)

Предназначена для групповой печати чеков. Что печатать в теле чека описано в текстовом файле с разделителем запятая (CSV) Подходит для любого языка программирования который умеет записывать в текстовый файл

3600 руб.

26.07.2019    25957    39    17    

24
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. letchik2000 31.10.14 14:01 Сейчас в теме
Автору спасибо за публикацию. Сразу видно - специалист.
Нужна помощь по доработке конкретной обработки выгрузки картинок из Excel в 1С 8.2 УТ 10.3.
В целом она работает нормально, однако иногда вылетают ошибки - например картинка привязывается к наименованию или артикулу из соседней строки или вообще не находится. При этом совершенно точно картинка привязана к соответствующей ячейке.
Если есть желание разобраться в этой проблеме и попутно подзаработать на хлебушек - буду рад рассказать о проблеме более подробно
Оставьте свое сообщение