В Python, учитывая каталог полноразмерных изображений, как я могу генерировать миниатюры, используя более одного CPU Core?

StackOverflow https://stackoverflow.com/questions/4066606

Вопрос

У меня есть 16-ядерная машина, но моя текущая функция изменений использует только одно ядро, которое действительно неэффективно для большого каталога изображений.

def generateThumbnail(self, width, height):
     """
     Generates thumbnails for an image
     """
     im = Image.open(self._file)
     (detected_width,detected_height) = im.size

     #Get cropped box area
     bbox = self.getCropArea(detected_width, detected_height, width, height)

     #Crop to box area
     cropped_image = im.crop(bbox)

     #Resize to thumbnail
     cropped_image.thumbnail((width, height), Image.ANTIALIAS)

     #Save image
     cropped_image.save(self._path + str(width) + 'x' +
             str(height) + '-' + self._filename, "JPEG")

Любая помощь будет очень ценится. Спасибо.

Это было полезно?

Решение

Это звучит как хорошее решение для многопроцессора Модуль, который использует интерфейс Threading, но создает отдельные процессы вместо потоков.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top