Возникла нужда сжать изображения, прикреплённые к номенклатуре. Так как пользователи при загрузке не церемонились и грузили в базу несжатый TIFF, по 10-37 Мбайт н картинку. Понятно, что база начала расти, и не только за счёт полезных данных.
Пробовал сделать сжатие с использованием встроенного механизма в 1С, который появился с платформы 8.3.14, но, оказалось, что он не способен работать с такими большими изображениями. Поэтому я решил использовать внешнюю программу XnView, с её пакетной обработкой файлов.
То есть выгрузка картинок во внешнюю папку. Обработка их (Обрезка и сжатие в jpeg). И загрузка обратно.
Сложность в том, что после выгрузки изображений - трудно определить, какое изображение к какой номенклатуре относится. Да и у одной номенклатуры может быть подгружено несколько изображений. Здесь я использовал функцию хеширования.
При создании имени файла оно состояло из двух частей: код элемента справочника номенклатуры и хеш изображения, которое выгружается. Главное, чтобы не было в одной номенклатуре двух абсолютно одинаковых изображений.)))
В процессе обработки важно сохранить названия файлов.
При загрузке делаем обратное действие:
Из имени файла берём код номенклатуры, к которой относится изображение. Потом по хешу, который в имени файла ищем изображение и меняем его.
Есть нюанс. При количестве позиций номенклатуры более 12000 возможен произвольное закрытие 1С. Причину так и не понял, к сожалению. Но, если запустить обработку заново, то она продолжит создание файлов. Но, к сожалению, всю базу будет обрабатывать заново. Если файл есть в папке выгрузки, то обработка его не будет создавать заново. Если файла нет, то создаст.
Таким образом всё действо делается в три этапа:
- В поле "Выгрузка" выбираем папку, куда будут выгружены изображения.
- Обрабатываем изображения из этой папки с помощью XnView. Выбираем пакетную обработку, и преобразование файлов в формат jpeg. По желанию указываем изменение размера изображения, до желаемого и поставим галочку "Только уменьшение", чтобы файлы, которые меньше размером не были увеличены. Указываем отдельную папку для сохранения результата.
- В поле "Загрузка" указываем папку с результатами обработки XnView. Жмём кнопку "Загрузить".
В идеале - всё было бы проверить на тестовой базе. Чтобы не сломать основную, если вдруг что-то пойдёт не так. )))
А только потом делать на рабочей.
Весь процесс на 14000 картинок с выгрузкой-обработкой-загрузкой занимает ориентировочно 3 часа.
Тестировалась на 10.3.30.1. Платформа 8.3.19.1467.