Skip to main content

App for various music-file-collection analyses (for example, chart of most popular artists in your MP3 collection) and AI playlist generation

Project description

muziqa

Analyze your music collection and generate interesting charts using command-line:

  • Top artists by track count
  • Tracks by decade
  • Tracks by year, with a 5-year rolling average of mean tracks per artist
  • Tracks by country (optional, see below)
  • Tracks by genre (optional, see below)

muziqa chart muziqa chart

Also create MP3 playlist using Anthropic Claude LLM. The generated playlist is an MP3 file of your songs, picked by AI, per your prompt. Example:

$ muziqa Music --playlist "Playlist of rock tunes where lead guitar is as close as possible to the picking style of Mark Knopfler. Max 1 hour. Max one song per artist." --playlist-output mark.mp3

Install

Linux / Mac:

$ pipx install muziqa

Windows (PowerShell; NOTE: untested):

winget install Python.Python.3   # if Python not already installed
pip install pipx
pipx ensurepath                  # restart terminal after this
pipx install muziqa

Windows + --playlist: also install ffmpeg: winget install ffmpeg

Usage

No API keys, no accounts, no streaming service — just point muziqa to a folder of music files:

$ muziqa /path/to/music

Reads tags from all supported files in the folder and subfolders, and saves two charts:

  • muziqa.png — top artists + tracks by decade
  • muziqa_years.png — tracks by year with rolling average

Supported formats: MP3, FLAC, WAV, M4A, OGG

Country and genre charts

$ muziqa /path/to/music --country
$ muziqa /path/to/music --genre
$ muziqa /path/to/music --country --genre

Looks up each artist's country of origin and genre from MusicBrainz and saves additional charts:

  • muziqa_country.png — tracks by country
  • muziqa_genre.png — tracks by genre

muziqa chart muziqa chart

Note: The first run with --country or --genre queries MusicBrainz for every unique artist at 1 request/second (required by their API). For a large collection this can take a bit of time. Using both flags together does not double the time — data is fetched in a single pass. Results are cached in muziqa_mb_cache.json so subsequent runs are instant.

Note on "Unknown" genre: This means MusicBrainz either didn't find the artist or has no community-submitted genre tags for them. It does not affect the rest of the chart.

All options

Option Description
DIR Directory of music files to analyze
--flat Search only the given folder, not subfolders
--country Fetch artist countries from MusicBrainz and plot by country
--genre Fetch artist genres from MusicBrainz and plot by genre
--output FILE Output image filename (default: muziqa.png)
--top N Number of top entries to show (default: 20)
-playlist DESC Create a playlist MP3 matching the given description (requires ANTHROPIC_API_KEY and ffmpeg)
--playlist-output FILE Output file for playlist (default: playlist.mp3)
--model MODEL Claude model for --playlist (default: claude-sonnet-4-6). Tip: use 'llm-models -p Anthropic' to list available models --> github.com/ljbuturovic/llm-models

Examples

$ muziqa ~/Music
$ muziqa ~/Music --flat
$ muziqa ~/Music --country --genre
$ muziqa ~/Music --top 30 --output top30.png

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

muziqa-1.1.3.tar.gz (13.5 kB view details)

Uploaded Source

Built Distribution

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

muziqa-1.1.3-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file muziqa-1.1.3.tar.gz.

File metadata

  • Download URL: muziqa-1.1.3.tar.gz
  • Upload date:
  • Size: 13.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.4

File hashes

Hashes for muziqa-1.1.3.tar.gz
Algorithm Hash digest
SHA256 4774c5ce23551f4b0cd35f013bd195ed1282b7e51c579c6c543c59b7f080df66
MD5 525ba61f6c3e21ad59f627f15384eaea
BLAKE2b-256 ad191b8cfdf022847ed1ff7a62dc5926a30b97b9b4204d603b2a9e99f201d498

See more details on using hashes here.

File details

Details for the file muziqa-1.1.3-py3-none-any.whl.

File metadata

  • Download URL: muziqa-1.1.3-py3-none-any.whl
  • Upload date:
  • Size: 13.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.4

File hashes

Hashes for muziqa-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 697b60b6bad3ee1c27111d761ae7aec81e1e7d3fb9d01f4ae2f4816ec3072199
MD5 f7aaa89f6b1c7c228640158c691993c7
BLAKE2b-256 1911cd610bc1efeacc67379fbc266406eb3d02c4bb8c39930baf9629fa6bbe8f

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