Как проверить размеры всех изображений в каталоге с помощью Python?

Для чувствования себя подобно Вам нужна необратимая миграция, вероятно, знак, у Вас есть большие проблемы при смутном очертании. Возможно, некоторые специфические особенности помогли бы?

Что касается Вашего второго вопроса: Я всегда прилагаю 'усилия' для записи реверса миграций. Конечно, я на самом деле не пишу эти .down, TextMate вставляет его автоматически при создании .up.

11
задан john2x 1 October 2009 в 23:47
поделиться

3 ответа

Вы можете использовать Python Imaging Library (также известную как PIL) для чтения заголовков изображений и запроса размеров.

Один из способов приблизиться к этому - написать себя функция, которая принимает имя файла и возвращает размеры (используя PIL). Затем используйте функцию os.path.walk , чтобы просмотреть все файлы в каталоге, применяя эту функцию. Собирая результаты, вы можете создать словарь сопоставлений имя_файла -> размеры , а затем использовать составление списка (см. itertools ), чтобы отфильтровать те, которые не соответствуют требуемому размеру.

7
ответ дан 3 December 2019 в 02:11
поделиться

Один из распространенных способов - использовать PIL , библиотеку изображений python для получения размеров:

from PIL import Image
import os.path

filename = os.path.join('path', 'to', 'image', 'file')
img = Image.open(filename)
print img.size

Затем вам нужно перебрать файлы в вашем каталоге, проверить размеры соответствуют вашим требуемым размерам, и переместите те файлы, которые не совпадают.

9
ответ дан 3 December 2019 в 02:11
поделиться

Если вам не нужна остальная часть PIL, а вам просто нужны размеры изображений PNG, JPEG и GIF, тогда эта небольшая функция (лицензия BSD) отлично справится со своей задачей:

http://code.google.com/ p / bfg-pages / source / browse / trunk / pages / getimageinfo.py

import StringIO
import struct

def getImageInfo(data):
    data = str(data)
    size = len(data)
    height = -1
    width = -1
    content_type = ''

    # handle GIFs
    if (size >= 10) and data[:6] in ('GIF87a', 'GIF89a'):
        # Check to see if content_type is correct
        content_type = 'image/gif'
        w, h = struct.unpack("<HH", data[6:10])
        width = int(w)
        height = int(h)

    # See PNG 2. Edition spec (http://www.w3.org/TR/PNG/)
    # Bytes 0-7 are below, 4-byte chunk length, then 'IHDR'
    # and finally the 4-byte width, height
    elif ((size >= 24) and data.startswith('\211PNG\r\n\032\n')
          and (data[12:16] == 'IHDR')):
        content_type = 'image/png'
        w, h = struct.unpack(">LL", data[16:24])
        width = int(w)
        height = int(h)

    # Maybe this is for an older PNG version.
    elif (size >= 16) and data.startswith('\211PNG\r\n\032\n'):
        # Check to see if we have the right content type
        content_type = 'image/png'
        w, h = struct.unpack(">LL", data[8:16])
        width = int(w)
        height = int(h)

    # handle JPEGs
    elif (size >= 2) and data.startswith('\377\330'):
        content_type = 'image/jpeg'
        jpeg = StringIO.StringIO(data)
        jpeg.read(2)
        b = jpeg.read(1)
        try:
            while (b and ord(b) != 0xDA):
                while (ord(b) != 0xFF): b = jpeg.read(1)
                while (ord(b) == 0xFF): b = jpeg.read(1)
                if (ord(b) >= 0xC0 and ord(b) <= 0xC3):
                    jpeg.read(3)
                    h, w = struct.unpack(">HH", jpeg.read(4))
                    break
                else:
                    jpeg.read(int(struct.unpack(">H", jpeg.read(2))[0])-2)
                b = jpeg.read(1)
            width = int(w)
            height = int(h)
        except struct.error:
            pass
        except ValueError:
            pass

    return content_type, width, height
16
ответ дан 3 December 2019 в 02:11
поделиться
Другие вопросы по тегам:

Похожие вопросы: