В Python, учитывая каталог полноразмерных изображений, как я могу генерировать миниатюры, используя более одного CPU Core?
-
28-09-2019 - |
Вопрос
У меня есть 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, но создает отдельные процессы вместо потоков.
Не связан с StackOverflow