YouTube Downloader avatar
YouTube Downloader

Deprecated

Pricing

$5.00/month + usage

Go to Store
YouTube Downloader

YouTube Downloader

Deprecated

Developed by

ApiLabs

ApiLabs

Maintained by Community

All-in-One YouTube Downloader: Easily integrate our affordable solution into your application to download high-quality videos, audio, and music from YouTube. Enjoy customizable formats and quality options, all at a cheaper price compared to other tools.

0.0 (0)

Pricing

$5.00/month + usage

4

Total users

30

Monthly users

1

Last modified

5 days ago

YouTube Downloader API

Overview

The YouTube Downloader API provides a powerful and flexible solution for downloading videos, audio, and music from YouTube. With support for multiple formats like MP3 and MP4, users can choose their desired quality option for the best media experience. This all-in-one downloader is perfect for developers looking to integrate seamless media downloading capabilities into their applications.

Features

  • Download Video: Fetch and store high-quality videos from YouTube.
  • Download Audio: Extract and save audio tracks in various formats, including MP3.
  • YouTube Music: Access and download music videos directly from YouTube.
  • Format Options: Choose between MP3 and MP4 formats for your downloads.
  • Quality Selection: Select your preferred quality for downloads to ensure the best experience.

Input Parameters

The API accepts the following input parameters:

  • url: The URL of the YouTube video or audio content to download.
  • quality: The desired quality option for the download (e.g., 720p, 1080p, etc.).
  • onlyAudio: A boolean flag (true/false) indicating whether to download audio only.
  • useFFmpeg: A boolean flag (true/false) to specify if FFmpeg should be used for processing.
  • proxy: (Optional) The proxy URL to be used for the download.

Note: Using a proxy is recommended to avoid being blocked by YouTube. However, it may increase download times. If you experience any issues, consider changing your proxy.

Important Notes

  1. Proxy Usage: If you are using a proxy, please ensure that it is correctly configured and you are using a reliable proxy group. This will help avoid IP blocking by YouTube.

  2. QuickTime Note for Mac Users: If you are using macOS, the downloaded video may not work properly with QuickTime Player due to codec issues. In such cases, use a different media player like VLC, or convert the file format using a tool like FFmpeg.

  3. Video and Link Storage: Every time the API runs:

    • The video download link is stored in one dataset.
    • The actual video is stored in another dataset, enabling easy access and management of the media files.

Output

Upon a successful request, the API stores an item in the dataset the following format:

{
"download_link": "your_download_link_here",
"status_code": 200
}

Usage Example Python

The following example shows an full example of usage from running an actor to downloading the video on your device.

import requests
import mimetypes
from apify_client import ApifyClient
# Initialize the ApifyClient with an API token
# (You can generate your own Apify API token for authentication)
apify_client = ApifyClient('your_apify_api_token')
# Define the input for the actor that downloads YouTube videos
actor_input = {
"audioOnly": False, # Set to True if you only want to download audio, False for full video
"ffmpeg": True, # Whether to use ffmpeg for processing
"proxy": {
"useApifyProxy": True, # Enable the use of Apify Proxy
"apifyProxyGroups": ["RESIDENTIAL"], # Specify the proxy group to use (e.g., residential)
"apifyProxyCountry": "HR" # Set the country code for the proxy (e.g., HR for Croatia)
},
"url": "youtube_url" # The YouTube URL to download
}
# Start the actor on Apify and wait for it to finish
# (Replace 'demolitore/my-actor' with the actor you want to use)
actor_call = apify_client.actor('apilabs/youtube-downloader').call(run_input=actor_input)
# Retrieve the dataset associated with the YouTube downloader
my_dataset_client = apify_client.dataset('your_username/Youtube-Downloader')
# Fetch the most recent dataset entry, which contains the download link
l = my_dataset_client.list_items(limit=1, desc=True) #Get the only last element inserted
url = l.items[0]['download_link'] # Extract the download link from the dataset
# Download the file using the URL extracted from the dataset
response = requests.get(url)
# If the download is successful (status code 200), proceed to save the file
if response.status_code == 200:
# Get the Content-Type from the response headers to infer the file extension
content_type = response.headers.get('Content-Type')
# Guess the appropriate file extension based on the Content-Type
extension = mimetypes.guess_extension(content_type.split(';')[0])
# Extract the base filename from the URL and append the correct file extension
filename = url.split("/")[-1].split("?")[0]
filename = f"{filename}{extension}" # Combine the base filename with the extension
# Save the file to the local disk in binary mode
with open(filename, 'wb') as file:
file.write(response.content)
# Print success message with the saved filename
print(f"File downloaded successfully as {filename}.")
else:
# Print an error message if the download fails
print(f"Failed to download file. Status code: {response.status_code}")