django-storages / django_storages /

import os
from PIL import ImageFile as PILImageFile
from import FileSystemStorage

__all__ = ('ImageStorage',)

class ImageStorage(FileSystemStorage):
    A FileSystemStorage which normalizes extensions for images.

    Comes from

    def find_extension(self, format):
        """Normalizes PIL-returned format into a standard, lowercase extension."""
        format = format.lower()

        if format == 'jpeg':
            format = 'jpg'

        return format

    def save(self, name, content):
        dirname = os.path.dirname(name)
        basename = os.path.basename(name)

        # Use PIL to determine filetype

        p = PILImageFile.Parser()
        while 1:
            data =
            if not data:
            if p.image:
                im = p.image

        extension = self.find_extension(im.format)

        # Does the basename already have an extension? If so, replace it.
        # bare as in without extension
        bare_basename = basename if '.' not in basename else basename[:basename.rindex('.')]
        basename = bare_basename + '.' + extension

        name = os.path.join(dirname, basename)
        return super(ImageStorage, self).save(name, content)
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.