Bulk update image sizes in a directory

· 3 minute read

This script takes a specified directory, looks for images based on their file extensions (.png, .jpg, .jpeg, and more), and resizes them to a user-configurable width while maintaining their aspect ratio. The script then saves them to a target directory, rather than overwriting the original file, so you can confirm everything looks good.

Prerequisites

Aside from having Python installed, this script requires the Pillow library, which is a fork of PIL (Python Imaging Library). Example command for installation using Homebrew below.

brew install Pillow

Script


import argparse
from PIL import Image
import os

def resize_images(input_directory, output_directory, new_width):
  """
  Resize images in the specified input directory to a specified new width if they are wider than new_width, maintaining the aspect ratio, and save them to the output directory.
  """
  # Create the output directory if it doesn't exist
  if not os.path.exists(output_directory):
    os.makedirs(output_directory)

  for filename in os.listdir(input_directory):
	if filename.lower().endswith(('.png', '.jpg', '.jpeg', '.gif', '.webp')):
	  input_path = os.path.join(input_directory, filename)
	  output_path = os.path.join(output_directory, filename)

	  with Image.open(input_path) as img:
		# Only resize if the image is wider than the specified width
		if img.width > new_width:
		  # Calculate the new height to maintain the aspect ratio
          new_height = int((new_width / img.width) * img.height)
		  # Resize the image with high-quality resampling
		  img = img.resize((new_width, new_height), Image.Resampling.LANCZOS)
		  # Save the resized image
		  img.save(output_path)
		  print(f"Resized and saved: {filename}")
		else:
		  print(f"Skipped resizing: {filename}")

  print("Processing completed.")

if __name__ == "__main__":
  parser = argparse.ArgumentParser(description="Resize images to a specified width while maintaining aspect ratio, only if they are wider than the specified width.")
  parser.add_argument('input_directory', type=str, help='Directory containing the images.')
  parser.add_argument('output_directory', type=str, help='Directory to save the resized or copied images.')
  parser.add_argument('new_width', type=int, help='New width for the images.')
	
  args = parser.parse_args()
	
  resize_images(args.input_directory, args.output_directory, args.new_width)

Usage

The command takes three parameters:

  • input_directory: Directory containing the images to resize.
  • output_directory: Directory where resized images will be saved.
  • new_width: New width for the images.
python3 resize_images.py path/to/input/directory path/to/output/directory 800

This script can be easily adjusted to support other image file extensions supported by the Python Imaging Library. Reach out if you have any questions or recommendations for improvements.