A command line tool that fetches lyrics from various streaming providers.
You can install lyriks from PyPI using uv or pip:
# uv
uv tool install lyriks
# pip
pip install lyriksTo install it from source instead, clone the repository and build the wheel before installing it:
uv build
# uv
uv tool install dist/lyriks-*-py3-none-any.whl
# pip
pip install dist/lyriks-*-py3-none-any.whlYou can also run the script directly from within the repository:
./lyriks.py /path/to/music/folderMake sure to first install the required dependencies from pyproject.toml (i.e. uv sync).
Run the script with the path to the folder containing your music as an argument. This can be your whole collection, a single artist, or a single album.
lyriks /path/to/music/folderBy default, lyrics are fetched from Genie,
but you can switch to other providers with the --provider/-P flag.
Currently supported providers are:
The script will search for audio files (.flac or .mp3) in the given folder, and attempt to fetch the lyrics.
Note that it will only be able to do that for files that are properly tagged with MusicBrainz MBIDs
(specifically musicbrainz_releasegroupid and musicbrainz_trackid).
It then uses them to resolve the provider ID from the release or release group on MusicBrainz.
Thus, at least one release in the release group must have an album URL relationship for the selected provider.
If successful, the lyrics will be downloaded and stored next to the audio files with the appropriate extension
(.lrc or .txt, depending on whether they're synced or not).
For more information on usage, check the help message:
lyriks --helpYou can recursively ignore folders by adding a (empty) .nolyrics file inside the folder you want to exclude.
This can be useful for Western artists, where Genie is unlikely to have lyrics, or for instrumental releases.
Likewise, you can ignore specific songs by creating a file with the same name as the audio file
but the extension changed to .nolyrics.
For example, a track named 01 Song.flac can be excluded by creating a file named 01 Song.nolyrics.
Excluded files won't be queried at all, which can noticeably speed up the synchronisation process for large collections.