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.52.tar.gz (50.3 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.52-py3-none-any.whl (17.6 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for subtitle_tool-0.1.52.tar.gz
Algorithm Hash digest
SHA256 f0eb07cb998a9579fea02d5e5dfa25ce87aae77841c30a3d3a8f2fc526236ec5
MD5 91499591b1b200bb8d0d9a0e0488ee05
BLAKE2b-256 c1530a91605a6beb830f0a3b989189432ef828621db2faba4a0617e37209aa6c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for subtitle_tool-0.1.52-py3-none-any.whl
Algorithm Hash digest
SHA256 38cd62edd4c96aa4b15834cc145bec970cad73a14699fbdfad78f3700715d524
MD5 dc65b9b4af47e4b2262da907d5c113b4
BLAKE2b-256 bec4c1644575b0c052d536d2d0e80798045c1106f1d06c049a1fce4d8606e353

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