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.51.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.51-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: subtitle_tool-0.1.51.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.51.tar.gz
Algorithm Hash digest
SHA256 c75faf7b2b91bfe9b9a1b001f9cc2b64193cd774ee3449365f475afe63274c5f
MD5 3825b3e3c7c0cfcb48259825bb1d8674
BLAKE2b-256 cd71a798b759849d2613bcc8782d67f1ab91e4a062f0260294a2db87e49dedd7

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for subtitle_tool-0.1.51-py3-none-any.whl
Algorithm Hash digest
SHA256 f0de7d864a638c9bb364d753338f5653012e5fd3f9b6c1bb429e62580dce9d01
MD5 ee721d7c3f8b82ad0519ef41de598814
BLAKE2b-256 26e4dac8073c8ab1b2a2499ad162303693449041f7c31304ab4ce30d2399a42f

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