Skip to main content

This is an python API which allows you to get the transcripts/subtitles for a given YouTube video. It also works for automatically generated subtitles and it does not require a headless browser, like other selenium based solutions do!

Project description

YouTube Transcript/Subtitle API (including automatically generated subtitles)

This is an python API which allows you to get the transcripts/subtitles for a given YouTube video. It also works for automatically generated subtitles and it does not require a headless browser, like other selenium based solutions do!

Install

It is recommended to install this module by using pip:

pip install youtube_transcript_api

If you want to use it from source, you'll have to install the dependencies manually:

pip install -r requirements.txt

How to use it

You could either integrate this module into an existing application, or just use it via an CLI

In code

To get a transcript for a given video you can do:

from youtube_transcript_api import YouTubeTranscriptApi

YouTubeTranscriptApi.get_transcript(video_id)

This will return a list of dictionaries looking somewhat like this:

[
    {
        'text': 'Hey there',
        'start': 7.58,
        'duration': 6.13
    },
    {
        'text': 'how are you',
        'start': 14.08,
        'duration': 7.58
    },
    # ...
]

To get transcripts for a list fo video ids you can call:

YouTubeTranscriptApi.get_transcripts(video_ids)

CLI

Execute the CLI script using the video ids as parameters and the results will be printed out to the command line:

youtube_transcript_api <first_video_id> <second_video_id> ...

If you would prefer to write it into a file or pipe it into another application, you can also output the results as json using the following line:

youtube_transcript_api --json <first_video_id> <second_video_id> ... > transcripts.json

Warning

This code uses an undocumented part of the YouTube API, which is called by the YouTube web-client. So there is no guarantee that it won't stop working tomorrow, if they change how things work. I will however do my best to make things working again as soon as possible if that happens. So if it stops working, let me know!

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

youtube_transcript_api-0.1.0.tar.gz (3.9 kB view details)

Uploaded Source

Built Distribution

youtube_transcript_api-0.1.0-py3-none-any.whl (5.1 kB view details)

Uploaded Python 3

File details

Details for the file youtube_transcript_api-0.1.0.tar.gz.

File metadata

File hashes

Hashes for youtube_transcript_api-0.1.0.tar.gz
Algorithm Hash digest
SHA256 44b43c384b10582d5def4572c330e5e31bc5f968cd3611f2840a7565a9cf4a44
MD5 9fc6c617095a2789dcab7c4ec4437440
BLAKE2b-256 0a4ecd109c9a9b4d58db207bb48f47e397c44e2cc192df99bfef83b776496993

See more details on using hashes here.

File details

Details for the file youtube_transcript_api-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for youtube_transcript_api-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0f5acedc694ad4c94bbe7d055492d7e858540dddaa9f788bfba010b32d053dbf
MD5 515eafdcef37cfabe3e636f14cccdd39
BLAKE2b-256 2b42ecdf0410862dca1e725cd0dda2e561be072c96cf33775c07d239ea37d151

See more details on using hashes here.

Supported by

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