Skip to main content

A tool for generating subtitles using Google Gemini models.

Project description

Subtitle tool

codecov

This utility uses Google Gemini to generate subtitles to audio and video files.

Dependencies

ffmpeg needs to be installed for audio extraction.

Process

  1. Extract the audio from the video
  2. Send the audio to Gemini for transcription
  3. Backup the existing subtitle
  4. Save the new subtitle

Dependencies

  • Export the API key for Gemini to the environment variable GEMINI_API_KEY or specify it in the command line with the flag --api-key.

  • ffmpeg needs to be installed (brew install ffmpeg, apt-get install ffmpeg or dnf install ffmpeg)

  • Ensure uv installs its dev dependencies with uv sync --extra dev.

Installation

pip install subtitle-tool

Developing

For local development it is useful to install the binary from the development location into the user's PATH. For this, run the following commands:

uv tool install -e .
uv tool update-shell

Usage

  • Subtitle files with the defaults:
subtitle-tool video.avi
subtitle-tool audio.mp3
  • Usage options:
Usage: subtitle-tool [OPTIONS] MEDIAFILE

  Generate subtitles for a media file

Options:
  --api-key TEXT                  Google Gemini API key
  -m, --ai-model TEXT             Gemini model to use  [default:
                                  gemini-2.5-flash]
  -s, --subtitle-path TEXT        Subtitle file name [default: MEDIAFILE.srt]
  -v, --verbose                   Enable debug logging for subtitle_tool
                                  modules
  -d, --debug                     Enable debug logging for all modules
  -k, --keep-temp-files           Do not erase temporary files
  -l, --audio-segment-length INTEGER
                                  Length of audio segments to be subtitled in
                                  seconds  [default: 30]
  -p, --parallel-segments INTEGER
                                  Number of segments subtitled in parallel
                                  [default: 5]
  --help                          Show this message and exit.

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

subtitle_tool-0.1.50.tar.gz (50.0 kB view details)

Uploaded Source

Built Distribution

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

subtitle_tool-0.1.50-py3-none-any.whl (17.4 kB view details)

Uploaded Python 3

File details

Details for the file subtitle_tool-0.1.50.tar.gz.

File metadata

  • Download URL: subtitle_tool-0.1.50.tar.gz
  • Upload date:
  • Size: 50.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.4

File hashes

Hashes for subtitle_tool-0.1.50.tar.gz
Algorithm Hash digest
SHA256 8f248afbaa1a11c0d47c06ce4be5ccec119bc78ebe0f27f355f1ed3cd8b7d9a2
MD5 acbb79f02b9d76b2d79dc76a63705a21
BLAKE2b-256 020320f3a7b821fa41e65ce3402978bfb998b86c73a6dcc294a6b9cd285d2dde

See more details on using hashes here.

File details

Details for the file subtitle_tool-0.1.50-py3-none-any.whl.

File metadata

File hashes

Hashes for subtitle_tool-0.1.50-py3-none-any.whl
Algorithm Hash digest
SHA256 9668db027b36d533a654a07541a4bbe0d4683b864a978309c49b37cdfe3003fc
MD5 bd6a81ebcfdb774d500984110f7a10f1
BLAKE2b-256 28a708ffca4bed011d0c0b3b4c777aea0c716af3f93aa78176f18afa5f8630d2

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