Skip to main content

Python 3 library for downloading YouTube Videos.

Project description

pytubefix

PyPI - Downloads PyPI - License PyPI - Version

Python3 library for downloading YouTube Videos.

install:

pip install pytubefix

usage:

mp4 video download highest resolution:

from pytubefix import YouTube
from pytubefix.cli import on_progress
 
url = input("url >")
 
yt = YouTube(url, on_progress_callback = on_progress)
print(yt.title)
 
ys = yt.streams.get_highest_resolution()
ys.download()

If you want to save in .mp3 just pass the mp3=True parameter (MPEG-4 AAC audio codec):

from pytubefix import YouTube
from pytubefix.cli import on_progress
 
url = input("url >")
 
yt = YouTube(url, on_progress_callback = on_progress)
print(yt.title)
 
ys = yt.streams.get_audio_only()
ys.download(mp3=True) # pass the parameter mp3=True to save in .mp3

if you want to download complete playlists:

from pytubefix import YouTube
from pytubefix import Playlist
from pytubefix.cli import on_progress
 
url = input("url Here >")

pl = Playlist(url)

for video in pl.videos:
    ys = video.streams.get_audio_only()
    ys.download(mp3=True) # pass the parameter mp3=True to save in .mp3

if you want to add authentication

from pytubefix import YouTube
 
url = input("url Here >")

yt = YouTube(url, use_oauth=True, allow_oauth_cache=True, on_progress_callback = on_progress)
           
ys = yt.streams.get_audio_only()

ys.download(mp3=True) # you will only get the request to authenticate once you download

Subtitle/Caption Tracks:

viewing available subtitles:

from pytubefix import YouTube

yt = YouTube('http://youtube.com/watch?v=2lAe1cqCOXo')
subtitles = yt.captions

print(subtitles)

printing the subtitle tracks:

from pytubefix import YouTube
 

yt = YouTube('http://youtube.com/watch?v=2lAe1cqCOXo')

caption = yt.captions.get_by_language_code('en')
print(caption.generate_srt_captions())

now you can save subtitles to a txt file:

from pytubefix import YouTube
 

yt = YouTube('http://youtube.com/watch?v=2lAe1cqCOXo')

caption = yt.captions.get_by_language_code('en')
caption.save_captions("captions.txt")

Using Channels:

get the channel name:

from pytubefix import Channel

c = Channel("https://www.youtube.com/@ProgrammingKnowledge/featured")

print(f'Channel name: {c.channel_name}')

to download all videos from a channel:

from pytubefix import Channel

c = Channel("https://www.youtube.com/@ProgrammingKnowledge")

print(f'Downloading videos by: {c.channel_name}')

for video in c.videos:
    download = video.streams.get_highest_resolution().download()

to get a list of live streams:

from pytubefix import Channel

url_channel = input("url > ")

c = Channel(url_channel)

print("live streams :", c.livestreams_urls)

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pytubefix-1.10rc1.tar.gz (64.2 kB view details)

Uploaded Source

Built Distribution

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

pytubefix-1.10rc1-py3-none-any.whl (58.5 kB view details)

Uploaded Python 3

File details

Details for the file pytubefix-1.10rc1.tar.gz.

File metadata

  • Download URL: pytubefix-1.10rc1.tar.gz
  • Upload date:
  • Size: 64.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for pytubefix-1.10rc1.tar.gz
Algorithm Hash digest
SHA256 736fb6e067d14f8ae59c562e0b4195e9679d6d6e43a1fb8208b5bb46a19cc67f
MD5 5f12735278237f5e2a9e1ec52c9fb15b
BLAKE2b-256 412c0e88b5461ab3c1cd007f2ac79641a67951ad874998877afcf09257fbc347

See more details on using hashes here.

File details

Details for the file pytubefix-1.10rc1-py3-none-any.whl.

File metadata

  • Download URL: pytubefix-1.10rc1-py3-none-any.whl
  • Upload date:
  • Size: 58.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for pytubefix-1.10rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 e5ba43a913df174a950477544dd4349a5d7afe232d133cd275e17e4c9f983f54
MD5 4d92115252419b62b96bfb63de5e87c7
BLAKE2b-256 f4056cc4ec508ed359f09e64e6234bad72990e56b859cfbf76e5a747f595104d

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