Восстановление размеров картинок в Excel

19.09.13

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

Что делать, если искажается размер картинок.

При сохранении табличного документа в формате .xlsx могут искажаться размеры картинок (логотипы, диаграммы и т.п.).
Проблема осложняется тем, что в Excel размеры задаются не в метрических единицах, а в пунктах.
Чтобы восстановить размеры в мм, обработайте получившийся лист при помощи такого кода (увы, размер придется вновь задавать в коде или считывать из коллекции рисунков документа):

Процедура ПоправитьКартинки(Эксель)

	msoFalse=0;
	msoTrue=1;
	msoPicture=13;
	
	
	ТаблицаРазмеров=Новый ТаблицаЗначений;
	ТаблицаРазмеров.Колонки.Добавить("Height"); // в мм
	ТаблицаРазмеров.Колонки.Добавить("Width");

	
	
		нс=ТаблицаРазмеров.Добавить(); // логотип
		
		нс.Height=14;
		нс.Width=55;
		
		нс=ТаблицаРазмеров.Добавить(); // круговая диаграмма
		нс.Height=45;
		нс.Width=101;
		
			
	ы=0;
	Для Каждого Shape Из Эксель.ActiveSheet.Shapes Цикл

		Если Shape.Type=msoPicture  Тогда
			УстановитьРазмерРисунка(Эксель,Shape,ТаблицаРазмеров[ы].Height,ТаблицаРазмеров[ы].Width);		
			ы=ы+1;
		КонецЕсли;	
			
	КонецЦикла;	
	
	//Эксель.Visible = 1;	
	//Эксель.Quit();
	//Эксель = Неопределено;
	
КонецПроцедуры	

// Устанавливает новый размер рисунка в мм
// App_E - COM-объект Excel
Процедура УстановитьРазмерРисунка(App_E,Shape,Height,Width)
	msoFalse=0;
	msoTrue=1;
	mmTOpoints = App_E.CentimetersToPoints(0.1);
	
	Shape.LockAspectRatio = msoFalse;
	Heightmm = Shape.Height / mmTOpoints;
	Widthmm = Shape.Width / mmTOpoints;
	
	ScaleHeightK=Height/Heightmm ;
	ScaleWidthK=Width/Widthmm;
	
	Shape.ScaleHeight(ScaleHeightK,msoFalse,0); //непропорционально
	Shape.ScaleWidth(ScaleWidthK,msoFalse,0);   //непропорционально
	
	

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

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

Excel рисунки картинки искажение

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

  • 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    45986    583    71    

219

Загрузка и выгрузка в 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    232731    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    24926    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    12531    71    0    

29
Для отправки сообщения требуется регистрация/авторизация