Загрузка номенклатуры с картинками из прайс-листа документа Excel

25.03.16

Учетные задачи - Логистика, склад и ТМЦ

Загрузка картинок (рисунков) номенклатуры из файла Excel с прайс-листом без использования внешних библиотек и компонентов.

Скачать файл

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

Наименование По подписке [?] Купить один файл
ЗагрузкаИзЭксельСКартинками
.epf 10,41Kb ver:1.0
48
48 Скачать (1 SM) Купить за 1 850 руб.

Идея взята из комментария к теме:

//infostart.ru/public/69412/

Идея состоит в копировании рисунка в буфер обмена методом com объекта Excel. Из буфера обмена картинка копируется в созданный объект Excel диаграмма, а из нее сохраняется в графический файл. Из графического файла картинку можно добавить к номенклатуре уже штатными средствами.

Для каждого рисунка в документе вычисляется строка документа, в котором он находится, и таким образом сопоставляется с номенклатурой.

// В параметрах передаются объекты страницы документа Excel и картинки. 
// Функция возвращает номер строки документа, в котором находится рисунок
Функция ПолучитьНомерСтрокиОбъекта(СтраницаДокумента,Картинка)
	НомерСтроки = 0;
	ТекущаяПозиция = 0;
	ПозицияКартинки = Картинка.Top + 3; // на случай, если картинка выходит за границы строки документа добавляем 3 пикселя
	Пока ТекущаяПозиция < ПозицияКартинки Цикл
		НомерСтроки = НомерСтроки + 1;
		ВысотаСтроки = СтраницаДокумента.Rows(НомерСтроки).Height;
		ТекущаяПозиция = ТекущаяПозиция + ВысотаСтроки;
	КонецЦикла;
	Возврат НомерСтроки;
КонецФункции

.............

// Как загрузить номенклатуру из строк документа не привожу.
// Здесь только получение картинок и добавление к номенклатуре, раннее импортированной
// и указанной ссылками в таблице обработки, в которой номера строк соответствуют строкам документа 
	Excel     = Новый COMОбъект("Excel.Application");       
	WB         = Excel.Workbooks.Open(Объект.ФайлЗагрузки);       
	WS         = WB.Worksheets(1); 
	
	Если ЗагружатьКартинки Тогда
		WS1 = WB.Worksheets(2);  // Создаем диаграмму Excel    
		ДиаграммаXLS = WS1.ChartObjects().Add(0, 0, 100, 100);
		Для Н = 1 По WS.Pictures.Count() Цикл
			Картинка = WS.Pictures.Item(Н);
			НомерСтроки = ПолучитьНомерСтрокиОбъекта(WS, Картинка);
			Картинка.Copy(); // Копируем картинку в буфер обмена
			Ширина = Картинка.Width;
			Высота = Картинка.Height;
			ДиаграммаXLS.Width = Ширина * 1.01; // Устанавливаем размеры
			ДиаграммаXLS.Height = Высота * 1.01;
			ДиаграммаXLS.Chart.Paste(); 
			ДиаграммаXLS.Chart.Export("c:\TEMP\picture.jpg"); // Сохраняем картинку во временный файл
			
			Если НомерСтроки > 0 И НомерСтроки <= ТаблицаЦенИОстатков.Количество() Тогда
				ДвоичныеДанныеКартинки = Новый ДвоичныеДанные("c:\TEMP\picture.jpg");
				ДанныеКартинки = Новый Картинка(ДвоичныеДанныеКартинки);
				АдресДвоичныхДанныхКартинки = ПоместитьВоВременноеХранилище(ДвоичныеДанныеКартинки);
				Номенклатура = ТаблицаЦенИОстатков[НомерСтроки - 1].Номенклатура;
				ЗаписатьКартинкуНоменклатуры(АдресДвоичныхДанныхКартинки, Номенклатура, ДанныеКартинки.Формат());
			КонецЕсли;
				
		КонецЦикла;
	КонецЕсли;

Приложенная обработка не претендует на универсальность, в ней реализован импорт номенклатуры из прайса с жестко заданной структурой. Импортируется в конфигурацию Управление торговлей 11.2, используется определенный вид номенклатуры ("ТоварСКартинками", опционально с дополнительными свойствами "Состав" и "Произведено"). Графический файл сохраняется в каталоге C:\TEMP. В первой строке документа на первом листе Excel должны быть заголовки столбцов (не используется). Стобцы:

  • 1 - не используется
  • 2 - Наименование (обязательно)
  • 3 - не используется
  • 4 - Артикул
  • 5 - Производитель
  • 6 - Картинка (положение в строке не имеет значения) 
  • 7 - Состав (опционально)
  • 8 - Описание
  • 9 - Страна (опционально)
  • 10 - Цена
  • 11 - Количество

Обработку можно использовать в качестве шаблона для реализации импорта номенклатуры под собственные нужды.

импорт номенклатура Excel картинки

См. также

Логистика, склад и ТМЦ Бухгалтер Пользователь Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Оптовая торговля, дистрибуция, логистика Управленческий учет Платные (руб)

Программа позволяет организовать учет ответственного хранения товаров с весовыми характеристиками, в том числе со сроком годности и личным кабинетом Поклажедателя. Модуль реализован в виде расширения конфигурации, устанавливается в режиме 1С:Предприятие 8 за 5 минут по инструкции, что позволяет оставить конфигурацию 1С на стандартной поддержке и продолжать получать стандартные обновления от фирмы "1С".

89900 руб.

09.06.2020    41832    34    59    

69

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

1057

Загрузка и выгрузка в 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    38932    430    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    160931    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    27257    282    1    

135
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. luckardo 15 12.04.17 18:01 Сейчас в теме
выдает ошибку
Прикрепленные файлы:
2. Sova123 71 28.05.18 01:13 Сейчас в теме
{ВнешняяОбработка.ЗагрузитьНоменклатуру.Форма.Форма.Форма(94)}: Ошибка при вызове метода контекста (Worksheets)
WS1 = WB.Worksheets(2);
по причине:
Произошла исключительная ситуация (0x8002000b)
3. user970589 10 28.05.18 03:01 Сейчас в теме
Похоже на КЭШ. Удалите запись из базы 1С и вставьте ее заново.
Вообще - что за платформа, конфа, саму обработку выложите, как вам люди смотреть то будут?
Оставьте свое сообщение