Skip to main content

Simple tool to show Youtube music videos and lyrics for the playing Spotify songs

Project description

Spotify Music Videos

travis

A simple tool to show Youtube music videos and lyrics for the currently playing Spotify songs with VLC.

example

Requirements

  • Python 3.6+

For Linux users:

  • PyGI (not packaged on PyPi, you need to install it from your distribution's repository - it's usually called python-gi, python-gobject or pygobject). Here's a quick tutorial on how to install it on most systems.

  • GLib. You most likely have it installed already.

How to install

You can use pip to install it:

pip3 install spotify-videos

Or download the latest release. Uncompress the .tar.gz file and run inside the folder:

python3 ./setup.py install

Note: you can add the --user flag to install it locally.

Or you can just run it without installing it with:

python3 -m spotify_videos

Compatibility

For Windows and Mac users, the Spotify Web API will be used. This means that:

  • You have to sign in and set it up manually
  • Only Spotify Premium users are able to use some functions
  • API calls are limited to 1 per second so there is more lag

How to obtain your client ID and your client secret:

  1. Go to the Spotify Developers Dashboard
  2. Create a new client ID. You can fill the descriptions as you like. Click No when asked if it's a commercial integration and accept the Terms and Conditions in the next step.
  3. Go to Edit Settings and type http://localhost:8888/callback/ in the Redirect URIs field.
  4. You can now copy your Client ID and Client Secret and add them when you call spotify-videos by passing them as arguments or by exporting the enviroment variables so that you don't have to type them again:
    • spotify-videos --username your_username --client-id your_client_id --client-secret your_client_secret
    • export SPOTIPY_CLIENT_ID='your-spotify-client-id'; export SPOTIPY_CLIENT_SECRET='your-spotify-client-secret'

You may be prompted to paste the resulting link that was opened in your browser into the program. After doing it, the authorization process will be complete. The auth info should be kept in a cache file named .cache-[your_username]

How to use

You can use these flags to modify the behavior of the program:

usage: spotify-videos [-h] [-v] [--debug] [-n] [-f] [-a VLC_ARGS]
                      [--width MAX_WIDTH] [--height MAX_HEIGHT] [-w]
                      [--username USERNAME] [--client-id CLIENT_ID]
                      [--client-secret CLIENT_SECRET]

Windows and Mac users must pass --username, --client-id and --client-secret to
use the web API. Read more about how to obtain them in the README
(https://github.com/marioortizmanero/spotify-music-videos).

optional arguments:
  -h, --help            show this help message and exit
  -v, --version         show program's version number and exit
  --debug               display debug messages
  -n, --no-lyrics       do not print lyrics
  -f, --fullscreen      play videos in fullscreen mode
  -a VLC_ARGS, --args VLC_ARGS
                        other arguments used when opening VLC. Note that some
                        like args='--fullscreen' won't work in here
  --width MAX_WIDTH     set the maximum width for the played videos
  --height MAX_HEIGHT   set the maximum height for the played videos
  -w, --use-web-api     forcefully use Spotify's web API
  --username USERNAME   your Spotify username. Mandatory if the web API is
                        being used. Example: --username='yourname'
  --client-id CLIENT_ID
                        your client ID. Mandatory if the web API is being
                        used. Check the README to see how to obtain yours.
                        Example: --client-
                        id='5fe01282e44241328a84e7c5cc169165'
  --client-secret CLIENT_SECRET
                        your client secret ID. Mandatory if the web API is
                        being used. Check the README to see how to obtain
                        yours. Example: --client-
                        secret='2665f6d143be47c1bc9ff284e9dfb350'

Current limitations:

  • Spotify doesn't currently (15/07/19) support the MPRIS property Position so the starting offset is calculated manually and may be a bit rough.
  • Spotify's Web API doesn't allow function calls on updates like DBus, meaning that the metadata has to be manually updated every second and checked in case of changes.

Documentation

Helpful documentation links for contributing:

Running module locally:

python -m spotify_videos

Running tests with unittest:

python -m unittest or python -m unittest discover -s tests

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

spotify-videos-1.7.tar.gz (24.3 kB view details)

Uploaded Source

Built Distributions

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

spotify_videos-1.7-py3.7.egg (58.3 kB view details)

Uploaded Egg

spotify_videos-1.7-py3-none-any.whl (27.1 kB view details)

Uploaded Python 3

File details

Details for the file spotify-videos-1.7.tar.gz.

File metadata

  • Download URL: spotify-videos-1.7.tar.gz
  • Upload date:
  • Size: 24.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.4

File hashes

Hashes for spotify-videos-1.7.tar.gz
Algorithm Hash digest
SHA256 5274424cbb13fdef38e47ee88f976494e28988c97e03b5f94e9d53b6b3977ccb
MD5 fd1f93065f7c32b1b886596a6f13c3f6
BLAKE2b-256 e695cd543dbb69e07944fa06fb35a0dbe3dbcf42f630b8af92ecd00679e47997

See more details on using hashes here.

File details

Details for the file spotify_videos-1.7-py3.7.egg.

File metadata

  • Download URL: spotify_videos-1.7-py3.7.egg
  • Upload date:
  • Size: 58.3 kB
  • Tags: Egg
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.4

File hashes

Hashes for spotify_videos-1.7-py3.7.egg
Algorithm Hash digest
SHA256 a30c8f85cae31190ca11f99c1fd773281c2fe68edf8e3726b279e663de792e83
MD5 3e4cf3264f109698d26394c11c04ee92
BLAKE2b-256 7ae4cf5dcddb7a2fc9cc5e074ad5da6b38e9ad9ad44b23ca3e267b337c207c69

See more details on using hashes here.

File details

Details for the file spotify_videos-1.7-py3-none-any.whl.

File metadata

  • Download URL: spotify_videos-1.7-py3-none-any.whl
  • Upload date:
  • Size: 27.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.28.1 CPython/3.7.4

File hashes

Hashes for spotify_videos-1.7-py3-none-any.whl
Algorithm Hash digest
SHA256 d4c95644906f13fa01ce107eb92f6f3799b626c4723ac0215f0e92c197816048
MD5 f3f0e816f3f6c2e577aa9ea0166e54c5
BLAKE2b-256 1431224c1fe045f3a854711d6999bb0e9005c4a82d5dbfe0a9ee5886bb2c2411

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