Instagram Downloader avatar

Instagram Downloader

Try for free

2 hours trial then $5.00/month - No credit card required now

Go to Store
Instagram Downloader

Instagram Downloader

apilabs/instagram-downloader
Try for free

2 hours trial then $5.00/month - No credit card required now

Download high-quality reels, videos, with our all-in-one reel video downloader a budget-friendly solution that seamlessly integrates into your app.

Instagram Downloader API

Overview

The Instagram Downloader API provides a powerful and flexible solution for downloading reels, videos, audio, from Instagram Feed. 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 Instagram.
  • Download Audio: Extract and save audio tracks in various formats, including MP3.
  • 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 Instagram 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 Instagram. 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 Instagram.

  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:

1{
2  "download_link": "your_download_link_here",
3  "status_code": 200
4}

Usage Example Python

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

1import requests
2import mimetypes
3from apify_client import ApifyClient
4
5# Initialize the ApifyClient with an API token
6# (You can generate your own Apify API token for authentication)
7apify_client = ApifyClient('your_apify_api_token')
8
9# Define the input for the actor that downloads Instagram videos
10actor_input = {
11    "audioOnly": False,  # Set to True if you only want to download audio, False for full video
12    "ffmpeg": True,  # Whether to use ffmpeg for processing
13    "proxy": {
14        "useApifyProxy": True,  # Enable the use of Apify Proxy
15        "apifyProxyGroups": ["RESIDENTIAL"],  # Specify the proxy group to use (e.g., residential)
16        "apifyProxyCountry": "HR"  # Set the country code for the proxy (e.g., HR for Croatia)
17    },
18    "url": "Instagram_url"  # The Instagram URL to download
19}
20
21# Start the actor on Apify and wait for it to finish
22# (Replace 'demolitore/my-actor' with the actor you want to use)
23actor_call = apify_client.actor('apilabs/instagram-downloader').call(run_input=actor_input)
24
25# Retrieve the dataset associated with the Instagram downloader
26my_dataset_client = apify_client.dataset('your_username/Instagram-Downloader')
27
28# Fetch the most recent dataset entry, which contains the download link
29l = my_dataset_client.list_items(limit=1, desc=True) #Get the only last element inserted
30url = l.items[0]['download_link']  # Extract the download link from the dataset
31
32# Download the file using the URL extracted from the dataset
33response = requests.get(url)
34# If the download is successful (status code 200), proceed to save the file
35if response.status_code == 200:
36    # Get the Content-Type from the response headers to infer the file extension
37    content_type = response.headers.get('Content-Type')
38
39    # Guess the appropriate file extension based on the Content-Type
40    extension = mimetypes.guess_extension(content_type.split(';')[0])
41
42    # Extract the base filename from the URL and append the correct file extension
43    filename = url.split("/")[-1].split("?")[0]
44    filename = f"{filename}{extension}"  # Combine the base filename with the extension
45
46    # Save the file to the local disk in binary mode
47    with open(filename, 'wb') as file:
48        file.write(response.content)
49
50    # Print success message with the saved filename
51    print(f"File downloaded successfully as {filename}.")
52else:
53    # Print an error message if the download fails
54    print(f"Failed to download file. Status code: {response.status_code}")
Developer
Maintained by Community

Actor Metrics

  • 27 monthly users

  • 8 stars

  • >99% runs succeeded

  • 48 days response time

  • Created in Oct 2024

  • Modified 2 months ago