Skip to main content

A complete wrapper for the Search API provided by Spotify written in Python.

Project description

Spotify Search

LICENSE PIP

SearchSpotify is a complete wrapper for the Search API provided by Spotify written in Python.

It has built-in classes that helps you access the data returned by Spotify, alongside with useful methods for exporting data.

Check the documentation for more information on classes and methods.

What you can do

  • Get Spotify catalog information about albums, artists or tracks that match a keyword string.
  • Easily access the information provided by Spotify using specific class attributes and methods, such as name, id, url and many more.
  • Access and export audio and image files, such as album covers for example.

Installation

SearchSpotify depends on requests. You can easily install it by using PIP

python -m pip install requests

Then, you can safely install SearchSpotify using the following command:

python -m pip install searchspotify

Testing your installation

You can test your installation using python interactive shell

>>> import searchspotify

Getting access to the API

To get access to Spotify Search API, you need to have a Spotify account to get an access token, which is required by the API itself.
You can register an account if you don't have one.

Then, you need to login into your account in Spotify for Developers. Once you have successfully logged in, go to your Dashboard, and create a new application.

You should see something like this:

Once you've created your application, you'll receive a client ID and a client secret. These are your credentials, you should store them in a safe environment.

IMPORTANT: You should not store your credentials inside of your code if you're planning to publish it. You should use Environment Variables instead. Check this section to learn how to keep your credentials safe.

Making your first call

So now that you have your credentials, you can start making your calls to the API.

Open your editor and run the following code:

# First, we import our Client class from searchspotify.client
from searchspotify import Client

# Then, we create an instance of that class passing our credentials as arguments.
# IMPORTANT: Don't put your credentials inside your code if your planning to publish it.
myclient = Client("YOUR_CLIENT_ID", "YOUR_CLIENT_SECRET")

# Now we can call the method search() from our client and store the results in a new object.
results = myclient.search("Never gonna give you up")

# Then we call the method get_tracks() from our results object, which returns a list of tracks.
tracks = results.get_tracks()

# Now, let's access the first track in our list by using index 0.
track = tracks[0]

# Finally, we can access some information contained in our track.
print(track.name, "-", track.artists[0].name)
print(track.url)

#Using Album or Playlist links
playlist = myclient.search("https://open.spotify.com/playlist/37i9dQZEVXbmHwm9TPg9pf?si=fUjIaGonRlW3GfkZ9kuxFg")

p(f"Playlist title: {playlist.playlist_name}")
p(f"total tracks: {playlist.total_tracks}")
p(f"description: {playlist.description}")
p(f"total duration: {playlist.total_duration()}")
for track in playlist.tracks:
    print("Track Name:", track.track_name)
    print("Track URL:", track.spotify_url)
    print("Duration:", track.get_string_duration())


album = myclient.search("https://open.spotify.com/album/5nUuEb92id5CtdQCtOs7a1")

print("Album Name:", album.album_name)
print("Album Label:", album.label)
print("Album popularity:", album.popularity)
print("Album Thumb:", album.thumbnail_url)
print("Artists:", album.artists)
print("Release Date:", album.release_date)
print("Total Tracks:", album.total_tracks)
print("Total Duration:", album.total_duration_string())
for track in album.tracks:
    print("Track Name:", track.track_name)
    print("Track Number:", track.track_number)
    print("Track URL:", track.spotify_url)
    print("Duration:", track.get_string_duration())

This should be your result:

Never Gonna Give You Up - Rick Astley
https://open.spotify.com/track/4cOdK2wGLETKBW3PvgPWqT

That seems to be a lot of code, but you can simplify it a lot, like so:

from searchspotify.client import Client

myclient = Client("YOUR_CLIENT_ID", "YOUR_CLIENT_SECRET")
track = myclient.search("Never gonna give you up").get_tracks()[0]

print(track.name, "-", track.artists[0].name)

In a few lines of code, we got access to the API, retrieved some useful information of the first track in our results and displayed it.

There are a lot of class attributes and methods that you can use to retrieve the information you need, you can check them out in the documentation.

Keeping your credentials safe

As mentioned before, you should not store your credentials inside of your code. Specially if you are planning to publish it.

A safer way to store them is by using Environment Variables. Here's a complete tutorial on how to define and access environment variables using Python.

License

This project is under the terms of the MIT license.

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

searchspotify-0.1.0.tar.gz (13.7 kB view details)

Uploaded Source

Built Distribution

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

searchspotify-0.1.0-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file searchspotify-0.1.0.tar.gz.

File metadata

  • Download URL: searchspotify-0.1.0.tar.gz
  • Upload date:
  • Size: 13.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for searchspotify-0.1.0.tar.gz
Algorithm Hash digest
SHA256 32961204b05a5e2eae2c6344dfa1c224bffc3538b03a6cb14eb2b4196655a424
MD5 deb342402ef7f429aba0edc5743e71e7
BLAKE2b-256 af224c9075dd211820437cea76c5e4cd12efc8fcc418426ec5efd29eed9e4a65

See more details on using hashes here.

File details

Details for the file searchspotify-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: searchspotify-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 15.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for searchspotify-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6a97509b5ffd156469e8b2d2a826b6d579722ff508df85596122551533ecc438
MD5 f278669c8f656dee711d63a41fff6769
BLAKE2b-256 26032fae492c45823783dbcdbc0d1c3cd3deda1c1c7197383afb4993618afe77

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