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

02.08.10

Разработка - Разработка внешних компонент

Недавно столкнулся с необходимостью загрузки большого количества прайсов от различных книжных издательств. Обязательным условием было сохранение в базе данных информации вместе с картинками (обложками книг).

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
1CGClipboard.zip
.zip 205,95Kb
465 1 850 руб. Купить
ПримерИспользования.zip
.zip 200,96Kb
131 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Основной проблемой, конечно, стало сохранить картинку на диск.

Поначалу решил использовать cClipBoardObject.dll (автору компоненты большое спасибо за идею!), НО! Возникла следующая проблема: картинки сохраненные с помощью вышеуказанной компоненты имеют формат данных WMF (некоторые просмоторщики распознают как EMF) и при загрузке в базу картинки отображались некорректно, да и с конвертировать их при помощи Новый Картинка(...).Преобразовать(...) тоже не получилось - система упорно выдавала ошибку.

Решил написать собственную компоненту. Функционал небольшой:

2 свойства:

  • Тип файла/FileType - тип файла в который будет сохранено изображение из буфера обмена (0 - bmp, 1 - jpg, по умолчанию 1);
  • Сжатие/Compression - степень сжатия для файлов формата JPEG (значение по умолчанию 80);


1 Метод:

  • СохранитьИзБуфера/SaveFromClipboard(ПутьКФайлу);


Пока реализовано сохранение только для типа CF_MetaFilePict (WMF). При копировании из Excel картинки в буфер используется именно этот формат.
В будущем планирую расширить функционал компоненты и извлекать уже изображения и других типов.

Пример использования для 8.2.

На 7.7 тоже все работает.

Похожие разработки:

//infostart.ru/public/19872/

//infostart.ru/public/19932/

//infostart.ru/public/16800/

 

http://shkuraev.ru

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

См. также

Банковские операции Загрузка и выгрузка в Excel Бухгалтер Пользователь 1С v7.7 1C77 Россия Бухгалтерский учет Платные (руб)

Решение предоставляет комплексную загрузку банковской выписки из CSV, XLS, TXT файла в 1С 7.7 любой конфигурации. Позволяет создавать документы выбранного вида, например "Строка выписки банка (приход/расход)", или многострочный табличный документ, например Выписка, для каждой операции из загружаемого файла банковской выписки. Загружает реквизиты документа, а также создаёт контрагентов и другие необходимые элементы справочников.

3588 руб.

29.07.2021    24753    17    23    

18

Разработка внешних компонент Системный администратор Программист 1С v7.7 1С v8.3 1C v8.2 1С v8.1 Россия Платные (руб)

Аддон "Структура Обмена" (ExchangeStruc) - это компонента, которая обеспечивает доступ к разделяемым процессом структурам, аналогичным структурам 1С. Обеспечивает прозрачную передачу данных примитивных типов, в том числе Двоичных данных, в режиме Реального времени между разными контекстами (формами) или потоками одного процесса. В перспективе функционал будет расширен для обмена между процессами, даже разных версий платформ. Совместим с версиями Windows рабочих станций и серверов, с платформами 1С разных версий и релизов в режиме Native начиная с 8.2, и в режиме COM начиная с версий 7.7. По скорости чтения и записи лишь немногим уступает стандартной структуре 1С. НОВОЕ: Добавлен функционал регистрации компоненты COM в качестве OLE Auto (COMОбъект) для поддержки её работы в серверах старых версий 1С: 8.0 и 8.1, где работа с компонентами исключена. Теперь можно коммуникацию с Фоновыми заданиями на этих версиях проводить.

7200 руб.

19.04.2023    5648    1    0    

3

Разработка внешних компонент Программист 1С v7.7 Платные (руб)

Компонента для выбора значения из больших списков значений.

1200 руб.

02.12.2021    6629    2    19    

4

Разработка внешних компонент Защита ПО и шифрование Программист 1С v7.7 Абонемент ($m)

Цифровые подписи, шифрование, просмотр сертификатов ключей ЭЦП, работа с различными криптопровайдерами (в т.ч. КриптоПРО ГОСТ 2012) в 1С 7.7.

1 стартмани

08.06.2020    9901    29    mdbruyfn    10    

9

Разработка внешних компонент WEB-интеграция Программист 1С v7.7 Абонемент ($m)

Компонента позволяет использовать различные веб-сервисы интернет-ресурсов, например работать с онлайн-кассой через API, предоставленное ее разработчиком. Тестировалась на платформе 1С релиза 7.70.027.

1 стартмани

14.11.2019    20475    123    mdbruyfn    107    

18

Разработка внешних компонент Программист Пользователь 1С v7.7 1С v8.3 Транспорт, автопарки, такси Россия Платные (руб)

Программа "Компонента приёма веса для 1С, версия 3.0" позволяет принимать и заносить вес с весов непосредственно в программу "1С" - то есть, прием веса осуществляется целиком и полностью из программы "1С".

26400 руб.

09.04.2019    16846    2    9    

5

Разработка внешних компонент Загрузка и выгрузка в Excel Программист 1С v7.7 1C77 Абонемент ($m)

Внешняя компонента 1С 7.7. для сохранения таблиц в формате Excel 2007.

1 стартмани

21.03.2019    29110    77    MadDAD    303    

17

Разработка внешних компонент Программист 1С v7.7 1С v8.3 Россия Абонемент ($m)

Написанная Active-X компонента встраивается на форму обработки 1С (тестировалось на 1С 8.0, 8.1, 8.2, 8.3 не управляемые формы, 1С 7.7.). Компонента предназначена для моделирования игрового поля (вывод, движение спрайтов - фреймов, обработка коллизий, управление спрайтами-фреймами и т.д.) при разработки логики игры на встроенном языке 1С. Приложен пример обработки в которой реализована игра "Бита".

5 стартмани

04.01.2018    27235    2    protexprotex    34    

11
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. Поручик 4594 02.08.10 01:53 Сейчас в теме
Посмотри на это http://infostart.ru/public/19932/
И на источник разработки.
Работает со всеми распространёнными форматами.
2. salexdv 2372 02.08.10 07:08 Сейчас в теме
3. Magister 134 05.08.10 14:48 Сейчас в теме
Маньячество какое-то... а разве нельзя через VBA обратится к Excel и попросить его сохранить картинку на диск? С OpenOffice.org такое точно можно.
4. salexdv 2372 05.08.10 14:51 Сейчас в теме
(3) Может и можно... Если поделитесь наработками, буду очень признателен (и не я один) ;)
5. Magister 134 05.08.10 16:29 Сейчас в теме
(4) У меня-то и Excel на компе нет. А вот по работе с OO.o поделиться могу (правда пока делал только формирование файла с картинками, гиперссылками). Но методы для сохранения на диск у объекта GraphicObjectShape есть.
6. salexdv 2372 05.08.10 17:37 Сейчас в теме
(5) Это понятно, а как передать обратно в 1С путь к картинке, чтобы сделать все как в вышеозначенном примере?
7. Magister 134 05.08.10 18:01 Сейчас в теме
(6)
Что-то типа:
gProvider = Document.CreateInstance("com.sun.star.graphic.GraphicProvider");
Args = New COMSafeArray("VT_VARIANT", 2);
Args.SetValue(0, SetValue(ServiceManager, "URL", "file:///d:/123.jpg"));
Args.SetValue(1, SetValue(ServiceManager, "MimeType", "image/jpg"));
gProvider.storeGraphic(GraphicObjectShape.Graphic, Args);

Не проверял, но по идее должно работать.
8. salexdv 2372 05.08.10 18:51 Сейчас в теме
(7) Надо будет попробовать твое маньячество :D
9. CheBurator 3230 12.08.10 16:00 Сейчас в теме
Автор, посмотри проект Йоксель - там вроде сделано извлечение картинок
10. salexdv 2372 12.08.10 16:07 Сейчас в теме
(9) Хорошая вещь, только вот под свои нужды уже написал.
Рекомендую данную обработку отнести еще к
"ПРОГРАММИРОВАНИЕ → ОБМЕН ДАННЫМИ, ИНТЕГРАЦИЯ → 1C + Excel"
для облегчения поиска ;)
11. Альберт32 26.10.11 09:27 Сейчас в теме
12. egoel 28.02.12 09:42 Сейчас в теме
Это обработка для 8ки?
13. salexdv 2372 28.02.12 11:32 Сейчас в теме
(12) Да, эта обработка, как можно подгружать картинки из прайсов
14. titakovserg 16.03.12 10:43 Сейчас в теме
Отличная обработка. Кадровики просили перенести фотки сотрудников из Эксел; думаю несложно будет переработать эту вещь под мою задачу
15. salexdv 2372 16.03.12 10:54 Сейчас в теме
(14) Сложностей возникнуть не должно. Лучше для работы с буфером используйте усовершенствованную версию этой компоненты
16. Ламия 07.12.12 10:51 Сейчас в теме
Возможно глупый вопрос, а будет ли грузить, если картинки в прайсе и в отдельных файликах их нет?
17. salexdv 2372 07.12.12 11:15 Сейчас в теме
(16) Как раз для таких случаев, когда картинка только в прайсе присутствует
18. Ламия 07.12.12 11:59 Сейчас в теме
Чтож попробуем скачать и воспользоваться тогда, надеюсь все получится
19. Ламия 07.12.12 13:30 Сейчас в теме
А подскажите какого вида должен быть файл, в смысле что в какой колонке и в каком порядке.А то у меня просто создается куча пустых картинок в указанной папке,да и номенклатура никакая не грузится даже
20. salexdv 2372 07.12.12 14:48 Сейчас в теме
(19) В файле ПримерИспользования.zip есть образец прайса. Эта обработка служит примером получения картинки из excel, но она никак не сохраняет полученные данные. Просто на ее основе можно уже реализовать что-то свое
21. Ламия 07.12.12 16:16 Сейчас в теме
Млииин,так хотелось загрузить картинки
22. net7wolf 48 25.10.13 20:17 Сейчас в теме
23. midavp 1 10.02.16 15:08 Сейчас в теме
Скачал пример и файл. Создает пустые файлы картинок!
24. salexdv 2372 11.02.16 08:52 Сейчас в теме
(23) midavp, какая ОС используется и версия MS Office?
25. Yura77 30 09.11.16 10:31 Сейчас в теме
26. ДмитрийС 28.08.17 15:46 Сейчас в теме
Может кто подскажет, почему тестовая обработка не работает? Вернее, что я делаю не так.
Валится на ЗагрузитьВнешнююКомпоненту ("Не найдена компонента ""1CGClipboard"", без нее работа невозможна!").
Регистрировал её вручную. ПодключитьВнешнююКомпоненту проходит, а вот создать объект для работы с буфером обмена нет((
27. salexdv 2372 28.08.17 16:34 Сейчас в теме
(26) Если вы делаете так:
ЗагрузитьВнешнююКомпоненту("1CGClipboard.dll");

то dll должна лежать в каталоге исполняемых файлов программы.
Если компонента лежит где-то в другом месте, то надо вызывать так:
ЗагрузитьВнешнююКомпоненту("<ПутьКDll>\1CGClipboard.dll");
28. ДмитрийС 06.09.17 12:24 Сейчас в теме
(27) Спасибо за оперативный ответ! Извиняюсь за свой долгий ответ.
Думал у меня проблемы с рабочим компом (прав может не хватает), но я и дома проверил. Проблема осталась. Решил свой вопрос другим путем.
29. ClickUp 772 27.06.18 05:01 Сейчас в теме
Добрый день. Подскажите как решить проблему, Скачать Обработку и dll все зарегал все работает, но картинки не появляются и в папке создаются изображения с 0 размером. ОС Windows сервер 2008R2 и Excel 2007 (Пробовал на Windows 10 и Excel 2007 тот же результат), Помогите очень надо данный механизм.
30. salexdv 2372 27.06.18 07:30 Сейчас в теме
Здравствуйте! Попробуйте использовать эту разработку или её бесплатный аналог.
31. ClickUp 772 27.06.18 08:18 Сейчас в теме
Это же редактор картинок в 1с а мне надо получить картинку из excel в 1с
32. salexdv 2372 27.06.18 08:46 Сейчас в теме
(31) Это усовершенствованные версии. В них есть метод ПолучитьИзображение(). Если вызвать этот метод с пустым параметром, то картинка берется из буфера обмена. Потом остается вызвать только СохранитьИзображение()
Оставьте свое сообщение