Skip to main content

Search Youtube videos using python requests without Youtube API

Project description

youtube-search-requests

Search Youtube videos using python requests without Youtube API.

youtube-search-requests can search up to 120+ videos !

youtube-search-requests v0.0.2 can search unlimited videos !!!

Normally youtube-search-requests only extract urls, you can extract additional information by installing youtube-dl, for more information check usage below..

in v0.0.2, features like "validate", "extract_info", "include_related_videos" is gone, but dont worry "include_related_videos" will be back in future updates.

also, you don't need youtube-dl module anymore, youtube-search-requests now extract info by itself. And provide a very fast search rather than old version (v0.0.1)

CLI (Command Line Interface) Usage:


usage: python3 -m youtube_search_requests [-h] [-v] [--max-results={Number}] [-t={Number}] [-ei]
                                          [--json]
 			                   Search terms

Search Youtube videos using python requests without Youtube API

positional arguments:
  Search terms          a string terms want to search (if include space, you
                        must use double quotes "")

optional arguments:
  -h, --help            show this help message and exit
  --max-results={Number} 
                        maximum search results
  -t={Number} , --timeout={Number} 
                        give number of times to execute search, if times runs
                        out, search stopped & returning results
  --json                Return results in json format
  --json-output={Filename} 
                        Return results in output file based on json format
  --include-related-videos 
                        include all related videos each url's

example usage:

python3 -m youtube_search_requests "fish" --json

# {"urls": {'title': ..., 'url': 'https://www.youtube.com/watch?v=0gT8Ty0ClHc', thumbnails: [...], ...}}


Simple usage:

from youtube_search_requests import YoutubeSearch

y = YoutubeSearch('fish', max_results=10)
videos = y.search()

print(videos)

Search with given time usage:

from youtube_search_requests import YoutubeSearch

# given time 60 seconds for searching videos
y = YoutubeSearch('fish', max_results=10, timeout=60) 

# if search not complete after 60 seconds
# force it to return results
videos = y.search()

print(videos)

You might be wonder, how youtube-search-requests work ?

in-short-word:

youtube-search-requests work like Youtube in browsers (playing with POST and GET method).

in-long-word:

  • First, youtube-search-requests create a session for Youtube. (every opened youtube page in browser have it own session id)
  • Second, youtube-search-requests search videos using "internal Youtube API" that have been used youtube for searching videos in browsers.
  • There we go, done !!! :D.

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-search-requests-0.0.23.tar.gz (11.8 kB view details)

Uploaded Source

File details

Details for the file youtube-search-requests-0.0.23.tar.gz.

File metadata

  • Download URL: youtube-search-requests-0.0.23.tar.gz
  • Upload date:
  • Size: 11.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.22.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.54.1 CPython/3.8.5

File hashes

Hashes for youtube-search-requests-0.0.23.tar.gz
Algorithm Hash digest
SHA256 6339e9bc1427066d7b1889839347d385ca611c7cb965d582806b762738912dad
MD5 3d080847dbcf1086e6441147344d312f
BLAKE2b-256 98cbe717cac9110337237d2631206110ea92832a4e59dc68eba82ecebbf65875

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