Skip to main content

Import, rotate, crop and resize pictures into google Cloud Storage

Project description

cloudstorageimageresizer

A python module to import, rotate, crop and resize pictures into Google Cloud Storage

DISCLAIMER

THIS IS NOT AN OFFICIAL GOOGLE MODULE.

Synopsis

Typical usecase: fetch a bunch of image and generate thumbnails of various sizes for each of them, stored in Cloud Storage for further delivery via a CDN.

from cloudstorageimageresizer import ImageResizer

# Initialize an ImageResizer:
i = ImageResizer()

urls = [
    'http://www.gokqsw.com/images/picture/picture-3.jpg',
    'http://www.gokqsw.com/images/picture/picture-4.jpg'
]

for url in urls:

    # Fetch image into memory and store it in original format to a Google Cloud
    # Storage bucket
    i.fetch(url).store(
        in_bucket='my-images',
        key_name='image-original'
    )

    # Apply the image EXIF rotation, if any
    i.orientate()

    # Resize this image, store it into a Google Cloud Storage bucket and return its url
    url1 = i.resize(
        width=200
    ).store(
        in_bucket='my-images',
        key_name='image-w200'
    )

    # Do it again, with a different size
    url2 = i.resize(
        height=400
    ).store(
        in_bucket='my-images',
        key_name='image-h200'
    )

More explanation

For method parameters, see the code (there isn't much of it ;-)

ImageResizer does all image operations in-memory, without writing images to disk.

The ImageResizer instance is immutable: its internal image is never modified. Each image operation instead returns a clone of the ImageResizer loaded with the modified image. This allows you to chain image operations, and manipulate the same image in different ways without having to explicitely keep a backup copy of it.

ImageResizer uses PIL, has reasonable defaults for downsizing images and handle images with alpha channels nicely.

All images are stored in png format to preserve transparency.

Installation

cloudstorageimageresizer requires Pillow, which in turn needs external libraries. On Ubuntu, you would for example need:

sudo apt-get install libjpeg8 libjpeg8-dev libopenjpeg-dev

Then

pip install cloudstorageimageresizer

Testing

Add your JSON Google API credentials in the file gcloud-credentials.json, edit the BUCKET_NAME in example.py and run it:

python example.py

PEP8

The project follows the PEP8 convention.

It uses flake8 to check the code. If you've installed the dev-dependencies then you can just run the flake8-command and it'll tell you what needs to be fixed if applicable.

Source code

https://github.com/erwan-lemonnier/cloud-storage-image-resizer

Author and contributors

Erwan Lemonnier
github.com/pymacaron
github.com/erwan-lemonnier
linkedin.com/in/erwan-lemonnier/



Johan Wänglöf
github.com/jwanglof
linkedin.com/in/johan-w%C3%A4ngl%C3%B6f-09076192/

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

File details

Details for the file google-cloud-storage-image-resizer-2.37.0.tar.gz.

File metadata

  • Download URL: google-cloud-storage-image-resizer-2.37.0.tar.gz
  • Upload date:
  • Size: 6.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.15.0 pkginfo/1.7.0 requests/2.22.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.5.9

File hashes

Hashes for google-cloud-storage-image-resizer-2.37.0.tar.gz
Algorithm Hash digest
SHA256 c28005caf93fc99c6013988f84f256a3e097e676fe00e352d57ae6aea710624a
MD5 d4967e4303322c639d45ab478658daf4
BLAKE2b-256 2fed5913e6a9f63f8d70e6562e632b163262b4d932cf016664241160da8bbf9c

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page