Skip to main content

Takes Google Photos Album (visible to anyone with url) and produces a zip file with compressed JPEGS.

Project description

For more information about the author, visit LinkedIn.

Python Package - gPhotosAlbum_JPEGcompression

Overview

Short Description: Takes Google Photos Album (visible to anyone with url) and produces a zip file with compressed JPEGS.

USP:

  • The JPEGS retain the metadata.
  • 1.5x to 15x reduction in file size depending on the JPEG.
  • Larger files with higher megapixel undergo very good compression.
  • Almost perfect image clarity up to 250% magnification.

Release Notes

version 2.1.7

  • Big update, switched to using selenium web driver automation.
  • Auto config selenium, no need to lift a finger.
  • Include some additional tweaks and optimizations.

version 1.4.3

  • Some fixes (as always).

version 1.4.2

  • First public release of gPhotosAlbum_JPEGcompression.
  • JPEGS retain metadata.

Installation

You can install the package using pip:

pip install gPhotosAlbum_JPEGcompression

Methods

1. Simple usecase.

Takes the Google Photos Album url as Input. Ensure that the Photos are set to "Accesible by anyone with the url".

Returns: A zip file of the compressed images (JPEGs).

from gPhotosAlbum_JPEGcompression import compress_GoogleAlbum_jpeg


googleAlbumURL = "https://photos.app.goo.gl/loremimpsunm56"

compress_GoogleAlbum_jpeg(googleAlbumURL)

Parameters:

  • Gphotos_url (str): URL of the Google Photos album.
  • scroll_pause_time (float, optional, default=0.5): Time to pause during scrolling for dynamic loading.
  • isHeadless (bool, optional, default=True): Whether to run the browser in headless mode.
  • imageXpath (str, optional, default='//a[@tabindex="0"]/@href'): XPath expression to locate image URLs.
  • url_prefix (str, optional, default="https://photos.google.com/"): Prefix for image URLs.
  • output_path (str, optional, default="defaultlocationpreference"): Path where compressed images will be saved.
  • window_height (str, optional, default="1080"): Browser window height in pixels.
  • window_width (str, optional, default="1920"): Browser window width in pixels.
  • scalefactor (str, optional, default="0.70"): Scaling factor for images in normal mode.
  • headless_scalefactor (str, optional, default="0.3"): Scaling factor for images in headless mode.
  • headless_height (str, optional, default="19900"): Browser height in pixels when in headless mode.
  • headless_width (str, optional, default="2400"): Browser width in pixels when in headless mode.

2. Advanced usecases.

Takes the Google Photos Album url as Input. Ensure that the Photos are set to "Accesible by anyone with the url".

Returns: A zip file of the compressed images (JPEGs).

from gPhotosAlbum_JPEGcompression import compress_GoogleAlbum_jpeg

Gphotos_url = "https://photos.google.com/share/exampleAlbumURL"

compress_GoogleAlbum_jpeg(
    Gphotos_url=Gphotos_url,
    scroll_pause_time=1.0,  # Increase scrolling pause to ensure all images are loaded
    isHeadless=True,  # Run in headless mode for faster execution
    imageXpath='//a[@tabindex="0"]/@href',  # XPath for locating image links
    url_prefix="https://photos.google.com/",  # URL prefix for constructing image links
    output_path="/compressed_images",  # Specify output path for compressed files
    window_height="1080",  # Window size for normal mode
    window_width="1920",
    scalefactor="0.8",  # Image scaling factor for compression
    headless_scalefactor="0.3",  # Scaling factor when running in headless mode
    headless_height="19900",  # Browser height for headless mode
    headless_width="2400"  # Browser width for headless mode
)

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

gphotosalbum_jpegcompression-2.2.2.tar.gz (14.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gphotosalbum_jpegcompression-2.2.2-py3-none-any.whl (14.0 kB view details)

Uploaded Python 3

File details

Details for the file gphotosalbum_jpegcompression-2.2.2.tar.gz.

File metadata

File hashes

Hashes for gphotosalbum_jpegcompression-2.2.2.tar.gz
Algorithm Hash digest
SHA256 42aee8c12e2d49cf79440c37585ccd73befa48c3e3475d16fb081bc3d80966fc
MD5 ef1a226d7485db7a6351798da37e319d
BLAKE2b-256 5d8fb25dcae8a6480de878467ad22a8cb35eaef767c864e4b209386c25f2b144

See more details on using hashes here.

File details

Details for the file gphotosalbum_jpegcompression-2.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for gphotosalbum_jpegcompression-2.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 99c2a2b4296020a3501da9b1b837683d6bc539ea250a05d49a6a94e9a306c441
MD5 75a2ae58e09861e5bc5490c82c52abbb
BLAKE2b-256 0703eb94d161dad6665c7e183101f3bd3a5c8a6bc05777ece9e053c68254b515

See more details on using hashes here.

Supported by

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