Skip to main content

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

Project description

PyPI version info RTD Documentation

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

Installation

Simply install the library from PyPI:

python -m pip install asyncspotify

Documentation

The documentation can be found at readthedocs.

Usage

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')
   async for track in playlist:
      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 at 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.12.0.tar.gz (25.1 kB view details)

Uploaded Source

Built Distribution

asyncspotify-0.12.0-py3-none-any.whl (32.1 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: asyncspotify-0.12.0.tar.gz
  • Upload date:
  • Size: 25.1 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.8.0

File hashes

Hashes for asyncspotify-0.12.0.tar.gz
Algorithm Hash digest
SHA256 dc68a5df02d7a6c70ae339bdac84734794ded675c5c7fe719f3e98c25ec0d8cb
MD5 f7b72816952aac675ec5298eead37959
BLAKE2b-256 47d006e5cd20453a0b630de9c028e275343c7c91a2388d309a7f3f5a1e35abc7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: asyncspotify-0.12.0-py3-none-any.whl
  • Upload date:
  • Size: 32.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.8.0

File hashes

Hashes for asyncspotify-0.12.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c4e1692b5b387d11fa21f2a7c05d207bafa1a4f70face015d22e5e2a18ddc865
MD5 f7a325d5fbe2b6c8053afbfa92230c94
BLAKE2b-256 021c3f0c0ee15cbe62679f76bb072894ee804dc9e5880fb3c6676d9a7a821a76

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