This Python script, youtube_music_url_fetcher.py
, leverages the innertube
python library to retrieve youtube search data and youtubemusicapi
python library to retrieve information about songs based on a provided search term and pytube
for getting decipher urls from youtube. The script is designed to find the top 6 search results for a given song name, extract audio URLs for those songs, and fetch lyrics if available. Additionally, it provides a convenient function, get_song_data_from_name()
, for users to obtain information about a specific song.
Before using the script, ensure you have the following dependencies installed:
innertube
: for fetching video url from youtube 🌐ytmusicapi
: for getting lyrics of songs, correct song names 🎶pytube
: for getting song url without SignatureCipher ⏯concurrent.futures.ThreadPoolExecutor
: for parallelizing requests ⚡
You can install the dependencies using the following:
pip install innertube ytmusicapi pytube
-
Saving the file named
youtube_music_url_fetcher.py
in your working directory -
Import the necessary module in your project file:
import youtube_music_url_fetcher
-
Use the
get_song_data_from_name()
function fromyoutube_music_url_fetcher.py
to retrieve information about a song:full python code:
import youtube_music_url_fetcher song_info = youtube_music_url_fetcher.get_song_data_from_name(song_name="song name ") print(song_info)
Example Output:
[{"title":title,"lyric":lyric,"url":url,"thumbnail":thumbnail,"pytube_obj":pytube_obj}]
-
parameter :
spell_checking
defines weather to correct the spelling of the song use yt music searching -
parameter :
url_and_pytube_obj
defines weather to return the url and pytube object
full python code with ->
spell_checking = True , url_and_pytube_obj = True
:import youtube_music_url_fetcher song_info = youtube_music_url_fetcher.get_song_data_from_name(song_name="song name",spell_checking=True,url_and_pytube_obj=True) print(song_info)
Example Output:
[{"title":title,"lyric":lyric,"url":url,"thumbnail":thumbnail,"pytube_obj":pytube_obj}]
spell_checking
andurl_and_pytube_obj
's default value isTrue
full python code with ->
spell_checking = False , url_and_pytube_obj = True
:import youtube_music_url_fetcher song_info = youtube_music_url_fetcher.get_song_data_from_name(song_name="song name",spell_checking=False,url_and_pytube_obj=True) print(song_info)
Example Output:
[{"title":title,"lyric":None,"url":url,"thumbnail":thumbnail_url,"pytube_obj":pytube_obj}]
full python code with ->
spell_checking = True , url_and_pytube_obj = False
:import youtube_music_url_fetcher song_info = youtube_music_url_fetcher.get_song_data_from_name(song_name="song name",spell_checking=True,url_and_pytube_obj=False) print(song_info)
Example Output:
[{"title":title,"id":id,"thumbnail":thumbnail_url,"ytmusic_json":ytm}]
-
Use the
download_file()
function insidedownload_audio()
class fromyoutube_music_url_fetcher.py
to download the audio file:full python code:
import youtube_music_url_fetcher obj = youtube_music_url_fetcher.download_audio(audio_url="audio url extracted using this lib",file_name="name of file",del_file="for deleting the existing file with the same file name // pass a bool(True/False)") obj.download_file()
-
getting one url only:
full python code:
import youtube_music_url_fetcher url = youtube_music_url_fetcher.get_song_data_from_name(song_name="song name", url_only=True) print(url)
Example Output:
['https://.............']
-
getting url and downloading song:
full code:
import youtube_music_url_fetcher data = youtube_music_url_fetcher.get_song_data_from_name("song name ") print(data) downloader = youtube_music_url_fetcher.download_audio(audio_url=data[0]['url'],file_name="hi0.mp3",del_file=True) downloader.download_file()
eg: https://music.youtube.com/playlist?list=PLJZgy8BHofJ89xpAxeKbOFQ5nAOOf4GDI&si=2q11ybGr4ADUbfOa
- Keep your dependencies up to date for security and compatibility reasons.
Contributions are welcome! If you encounter any issues or have suggestions for improvements, please open an issue or submit a pull request.
USE THE SOFTWARE AT YOUR OWN RISK.THE AUTHOR(S) DISCLAIM ANY WARRANTY OR GUARANTEE OF ITS PERFORMANCE, ACCURACY, OR SUITABILITY FOR ANY PARTICULAR PURPOSE. THE AUTHOR(S) PROVIDE THIS SOFTWARE 'AS IS' WITHOUT ANY WARRANTY. THEY ARE NOT RESPONSIBLE FOR ANY ISSUES OR CONSEQUENCES ARISING FROM THE USE OF THIS SOFTWARE.
This project and its contents are not affiliated with, funded, authorized, endorsed by, or in any way associated with YouTube, Google LLC or any of its affiliates and subsidiaries.
Any trademark, service mark, trade name, or other intellectual property rights used in this project are owned by the respective owners.