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.4.tar.gz (20.7 kB view details)

Uploaded Source

Built Distribution

asyncspotify-0.11.4-py3-none-any.whl (28.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: asyncspotify-0.11.4.tar.gz
  • Upload date:
  • Size: 20.7 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.4.tar.gz
Algorithm Hash digest
SHA256 6076d293e1270d5f48d03979349c3524b0ff5605353b4682dfe1c1b1952b797e
MD5 cd1cc8e43795dd620d32cba94bc048b7
BLAKE2b-256 6902d0b5b503e3a788511b0c5a36e04572cdd9e5d40bf339862a6f97fb80e2a6

See more details on using hashes here.

File details

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

File metadata

  • Download URL: asyncspotify-0.11.4-py3-none-any.whl
  • Upload date:
  • Size: 28.0 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 66b31c2f32b785faeec49b92f7a02a0d86c2b614ea0b6eeba733d9f7354f6c24
MD5 c02425e02b7882686d9d5b23de8e5254
BLAKE2b-256 b21adf446bfb7976ecd1c6e8c89e17a230895f36b8dc699b6c14d2532adc556e

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