Skip to main content

Fetch the currently playing song from Spotify and display the lyrics in terminal or a browser tab. Very fast.

Project description

SwagLyricsSwagLyrics-For-Spotify

Discord Server Build Status Build Status PyPI Downloads

Fetches the currently playing song from Spotify on Windows, Linux and macOS and displays the lyrics in the command-line or in a browser tab. Refreshes automatically when song changes. The lyrics are fetched from Genius. Turns out Deezer already has this feature in-built but with swaglyrics, you can have it in Spotify as well.

I'm mainly trying to build this project as far as I can, for practice and to learn and work with more technologies and platforms.

Initially developed this for personal use. Pretty much functionality oriented -- I usually develop something that I can see helping me and other users in the same situation. Packaged so I can first hand handle production-ready code to an extent and to make distribution and usage easier.

Why SwagLyrics?

SwagLyrics is the fastest and the most accurate package for getting lyrics.1

Provided optimal internet, SwagLyrics can fetch lyrics for a track in as less as 0.28s.2

It also does not require the user to generate any sort of API token (Spotify or Genius) and serves functionality right off the bat. This is possible as the song identification is done using our in-house library SwSpotify which does it locally for all operating systems.

The enhanced user experience is possible due to the backend which manages creating issues for unsupported songs and then adding support for them where possible by employing various techniques. Any song with lyrics on Genius can be supported without any user interaction owing to the backend. If say, lyrics do not exist for a track then subsequent playings of that track will not waste your resources in trying to fetch lyrics, this is done by a master list of unsupported songs which is handled by the backend as well.

1. [results] Tested against LyricsGenius, the most popular similar package on the US Top 50 Chart on Spotify. SwagLyrics was fractionally more accurate and 2.4x times faster.
2. [results] Speed and accuracy benchmark using Google Colab on the Spotify US Top 50 chart.

Installation

Requires Python 3.6+. Use pip or pip3 depending on your installation. You might want to use the --user flag on Linux to avoid using pip as root.

pip install swaglyrics

Usage

usage: swaglyrics [-h] [-t] [-c] [-n]

Either the tab or cli argument is required to output lyrics.

Arguments:

  -h, --help      show this help message and exit       
  -t, --tab       Display lyrics in a browser tab.      
  -c, --cli       Display lyrics in the command-line.   
  -n, --no-issue  Disable issue-making on cli.

You can quit by pressing Ctrl+C.

Before using, you should check USING.txt to comply with the Genius ToS. There's a copy included inside the package as well.

Note: If you have trouble displaying Japanese/Chinese characters on the command-line, simply type chcp 936 to change your code page. List of code pages can be found here: https://en.wikipedia.org/wiki/Code_page

Community

Changelog

  • v1.2.0

    • Add Genius A/B support
    • Add support for Bollywood songs
    • Add update check only once per 24h
    • Add parameter to force update check

See CHANGES.md for prior release notes.

Compiling SwagLyrics for Development

  • Clone the repo by git clone https://github.com/SwagLyrics/SwagLyrics-For-Spotify.git or use ssh.
  • cd into the cloned repo.
  • pip install -e . the -e flag installs it locally in editable mode.

Improvements Planned

  1. Linux and macOS support done
  2. Better logging of unsupported songs, the isolated unsupported.txt is sub-optimal for multiple users since the file will only update locally with songs which worked fine when it was just me but since I hope others use it too, I'll try to add a better method with server support.
  3. Better tests to test all of the functionality. (cli.py fully tested!) 100% code coverage
  4. Perhaps a tiny app using Electron that could fit in your tray to be opened whenever you want lyrics for a song.
  5. Supporting more songs, currently the program sometimes fails at remixes since while the lyrics are same as original, the artist is the remixer. done
  6. Documenting all the files.

SwagLyrics on Windows with Terminal

SwagLyrics with Hyper

SwagLyrics on Windows with Firefox Side-View

SwagLyrics with Side-View

Screencast - SwagLyrics on Linux

Watch the video

Screencast - SwagLyrics on macOS

Watch the video

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

swaglyrics-1.2.2.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

swaglyrics-1.2.2-py3-none-any.whl (14.9 kB view details)

Uploaded Python 3

File details

Details for the file swaglyrics-1.2.2.tar.gz.

File metadata

  • Download URL: swaglyrics-1.2.2.tar.gz
  • Upload date:
  • Size: 15.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.6.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.6

File hashes

Hashes for swaglyrics-1.2.2.tar.gz
Algorithm Hash digest
SHA256 0534e46f538582ca2a5888b2e931f9f10750984b7555d971796fa83dda875eb1
MD5 c625807561eb908f12219c412131e0a0
BLAKE2b-256 008a6c5b1ce2d41891c196fdb57a037eee7727f993b5bab06cbeb344eeb23f22

See more details on using hashes here.

File details

Details for the file swaglyrics-1.2.2-py3-none-any.whl.

File metadata

  • Download URL: swaglyrics-1.2.2-py3-none-any.whl
  • Upload date:
  • Size: 14.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.6.0 requests-toolbelt/0.9.1 tqdm/4.48.2 CPython/3.7.6

File hashes

Hashes for swaglyrics-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a7270d28fde038d7bf195124ded48e86b6a993ef6f5d3e8aae8c1bb698e02d66
MD5 96463f7a7778a78cb5dd71a2c64b7df2
BLAKE2b-256 b7e2cf55eea32b485752d9e5330a428ac8264f1eb7ac129167d7d4948e90fd53

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