Skip to main content

Spotify Web API implementation that is fully asynchronous and object-oriented.

Project description

asyncspotify

asyncspotify is an asynchronous, object-oriented python wrapper for the Spotify Web API.

Installation

Simply install it from PyPi using pip!

pip install asyncspotify

Documentation

The official documentation can be found on readthedocs: https://asyncspotify.readthedocs.io/

Usage

The library provides easy to use authentication functions and intuitive method and hierarchies.

To get going quickly, read the quickstart.

For complete examples, please check the documentation. Here's some snippets:

Authenticating using the Client Credentials flow, and getting a playlist:

from asyncspotify import Client, ClientCredentialsFlow

auth = ClientCredentialsFlow(
    client_id='your client id',
    client_secret='your client secret',
)

async with Client(auth) as sp:
    playlist = await sp.get_playlist('1MG01HhbCvVhH9NmXhd9GC')
    for track in playlist.tracks:
        print(track.name)

Searching for and getting tracks:

results = await sp.search_tracks(q='involvers', limit=2)
# [<SimpleTrack id='5xoJhWwvzPJD9k8j8BE2xO' name='27'>, <SimpleTrack id='0WUTBejxPUhURFCFfSYbDc' name='Fighting My Fight'>]

track = await sp.get_track('0hqAWKZDhuOfFb6aK002Ph')
# <FullTrack id='0hqAWKZDhuOfFb6aK002Ph' name='Bone Dry'>

Fetching and creating playlists:

# get a playlist
playlist = await sp.get_playlist('1wPvaRtuI8mt10CpP2KnlO')
# <FullPlaylist id='1wPvaRtuI8mt10CpP2KnlO' name='my playlist'>

# iterate through playlist tracks
for track in playlist.tracks:
    print(track)

# get current user
me = await sp.get_me()
# <PrivateUser id='runie13'>

# create new playlist
my_playlist = await me.create_playlist(name='My playlist!')
# <FullPlaylist id='0YTCnj0WE5gGb1lRqD6Ks9' name='My playlist!'>

# add tracks from previews playlist to the new playlist
await my_playlist.add_tracks(*playlist.tracks)

Reporting bugs

Please report issues here on GitHub.

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

asyncspotify-0.11.0.tar.gz (17.9 kB view details)

Uploaded Source

Built Distribution

asyncspotify-0.11.0-py3-none-any.whl (24.1 kB view details)

Uploaded Python 3

File details

Details for the file asyncspotify-0.11.0.tar.gz.

File metadata

  • Download URL: asyncspotify-0.11.0.tar.gz
  • Upload date:
  • Size: 17.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.5

File hashes

Hashes for asyncspotify-0.11.0.tar.gz
Algorithm Hash digest
SHA256 7f122be8232909853d4325a9aa8fd8135bc288561c0a1b4a87f708ae6bf9e032
MD5 61701527ac2d99ef8c649783f3f33168
BLAKE2b-256 f43ca12ee13cef07a11590fd7d92a16c713c852433eb7801fe12f60944517c50

See more details on using hashes here.

File details

Details for the file asyncspotify-0.11.0-py3-none-any.whl.

File metadata

  • Download URL: asyncspotify-0.11.0-py3-none-any.whl
  • Upload date:
  • Size: 24.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/40.8.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.5

File hashes

Hashes for asyncspotify-0.11.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c509a833955c34dc101095b5cc026f8b8d363ea7212c150192e37f8060e440a5
MD5 465b19eb6af4b4f818d2d0787052e879
BLAKE2b-256 d3335a4848d96f7d6d3f6fa618ec3de2da9bc80763495861df401232a867a0cf

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page