Skip to main content

Lyrics word frequency analyzer using Genius API

Project description

BarScan

A Python CLI tool that analyzes word frequency in song lyrics using the Genius API.

Features

  • Fetch lyrics for any artist from the Genius API
  • Analyze word frequency across multiple songs
  • Natural language processing with NLTK for accurate tokenization
  • Customizable stop word filtering and exclusions
  • Multiple output formats: table, JSON, CSV, and WordGrain
  • Local caching to reduce API calls and improve performance
  • Retry logic with exponential backoff for robust API communication

Installation

Prerequisites

  • Python 3.11 or higher
  • pip (latest version recommended)

From PyPI (when published)

pip install barscan

From Source

git clone https://github.com/shimpeiws/barscan.git
cd barscan
pip install -e ".[dev]"

Setup

Getting a Genius API Token

  1. Go to Genius API Clients
  2. Sign in with your Genius account (or create one)
  3. Click "Create an API Client"
  4. Fill in the app details:
    • App Name: Any name (e.g., "BarScan CLI")
    • App Website URL: Any URL (e.g., your GitHub profile)
    • Redirect URI: Leave default or use http://localhost
  5. Click "Save"
  6. Copy the "Client Access Token" (not the Client ID or Secret)

Configuring the Token

Set the token as an environment variable:

export BARSCAN_GENIUS_ACCESS_TOKEN=your_token_here

Or create a .env file in your project directory:

BARSCAN_GENIUS_ACCESS_TOKEN=your_token_here

Usage

Basic Analysis

Analyze the most common words in an artist's lyrics:

barscan analyze "Kendrick Lamar"

Command Options

# Analyze more songs
barscan analyze "Drake" --max-songs 20

# Show more words in results
barscan analyze "J. Cole" --top 100

# Combine options
barscan analyze "Tyler, The Creator" -n 15 -t 50

Output Formats

# Default table format (console)
barscan analyze "Beyonce"

# JSON format
barscan analyze "Beyonce" --format json

# CSV format
barscan analyze "Beyonce" --format csv

# WordGrain format (structured JSON schema)
barscan analyze "Beyonce" --format wordgrain

# Save to file
barscan analyze "Beyonce" --format json --output results.json

Filtering Options

# Disable stop word filtering (include "the", "a", "is", etc.)
barscan analyze "Eminem" --no-stop-words

# Exclude specific words
barscan analyze "Eminem" --exclude "yeah" --exclude "oh"

# Combine exclusions
barscan analyze "Eminem" -e "uh" -e "like" -e "yo"

Cache Management

BarScan caches lyrics locally to reduce API calls:

# Clear all cached lyrics
barscan clear-cache --force

# Clear only expired cache entries
barscan clear-cache --expired-only --force

# Interactive confirmation (without --force)
barscan clear-cache

View Configuration

# Show current configuration and cache statistics
barscan config

Configuration Options

All settings can be configured via environment variables with the BARSCAN_ prefix:

Variable Description Default
BARSCAN_GENIUS_ACCESS_TOKEN Genius API access token (required)
BARSCAN_CACHE_DIR Directory for caching lyrics ~/.cache/barscan
BARSCAN_CACHE_TTL_HOURS Cache time-to-live in hours 168 (7 days)
BARSCAN_DEFAULT_MAX_SONGS Default number of songs to analyze 10
BARSCAN_DEFAULT_TOP_WORDS Default number of top words to show 50

Output Formats

Table Format (default)

Human-readable table with word rankings:

Artist: Kendrick Lamar
Songs analyzed: 10
Total words: 5,432
Unique words: 1,203

Word Frequencies
┌──────┬─────────┬───────┬────────────┐
│ Rank │ Word    │ Count │ Percentage │
├──────┼─────────┼───────┼────────────┤
│ 1    │ love    │ 87    │ 1.60%      │
│ 2    │ know    │ 65    │ 1.20%      │
│ ...  │ ...     │ ...   │ ...        │
└──────┴─────────┴───────┴────────────┘

JSON Format

Structured JSON for programmatic use:

{
  "artist": "Kendrick Lamar",
  "songs_analyzed": 10,
  "total_words": 5432,
  "unique_words": 1203,
  "frequencies": [
    {"word": "love", "count": 87, "percentage": 1.60},
    {"word": "know", "count": 65, "percentage": 1.20}
  ]
}

CSV Format

Comma-separated values for spreadsheet import:

word,count,percentage
love,87,1.60
know,65,1.20

WordGrain Format

WordGrain is a standardized JSON schema for vocabulary analysis data. It enables interoperability between different word frequency analysis tools.

Output example:

{
  "$schema": "https://raw.githubusercontent.com/shimpeiws/word-grain/main/schema/v0.1.0/wordgrain.schema.json",
  "meta": {
    "source": "genius",
    "artist": "Kendrick Lamar",
    "generated_at": "2024-01-15T10:30:00Z",
    "corpus_size": 10,
    "total_words": 5432,
    "generator": "barscan/0.1.0",
    "language": "en"
  },
  "grains": [
    {"word": "love", "frequency": 87, "frequency_normalized": 160.18}
  ]
}

Development

Setup

# Clone repository
git clone https://github.com/shimpeiws/barscan.git
cd barscan

# Install with development dependencies
pip install -e ".[dev]"

Running Tests

# Run all tests with coverage
pytest

# Run specific test file
pytest tests/test_genius/test_client.py -v

# Run specific test
pytest tests/test_genius/test_client.py::TestSearchArtist::test_search_artist_success -v

Code Quality

# Lint code
ruff check src/

# Format code
ruff format src/

# Type check
mypy src/barscan/ --ignore-missing-imports

Architecture

src/barscan/
├── cli.py          # Typer CLI entry point (barscan command)
├── config.py       # Pydantic Settings configuration
├── exceptions.py   # Exception hierarchy (BarScanError base)
├── genius/         # Genius API integration
│   ├── models.py   # Pydantic models (Artist, Song, Lyrics)
│   ├── client.py   # GeniusClient with retry logic
│   └── cache.py    # File-based lyrics cache with TTL
├── analyzer/       # Word frequency analysis
│   ├── models.py   # Analysis result models
│   ├── processor.py # Text preprocessing with NLTK
│   ├── filters.py  # Stop word and length filtering
│   └── frequency.py # Word counting and aggregation
└── output/         # Result formatting
    └── wordgrain.py # WordGrain schema export

Troubleshooting

"Genius API token not configured"

Make sure you've set the BARSCAN_GENIUS_ACCESS_TOKEN environment variable or created a .env file with the token.

"Artist not found"

  • Check the spelling of the artist name
  • Try using the artist's name exactly as it appears on Genius
  • Some artists may have limited or no presence on Genius

Rate Limiting

BarScan includes automatic retry logic with exponential backoff. If you encounter rate limiting:

  • The tool will automatically retry failed requests
  • Consider reducing --max-songs for large analyses
  • Cached lyrics won't trigger new API calls

Empty Results

If no words appear in results after filtering:

  • Try --no-stop-words to include common words
  • Check if the artist has lyrics available on Genius
  • Some songs may be instrumental or have no lyrics

License

MIT

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

barscan-0.2.2.tar.gz (63.1 kB view details)

Uploaded Source

Built Distribution

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

barscan-0.2.2-py3-none-any.whl (43.6 kB view details)

Uploaded Python 3

File details

Details for the file barscan-0.2.2.tar.gz.

File metadata

  • Download URL: barscan-0.2.2.tar.gz
  • Upload date:
  • Size: 63.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for barscan-0.2.2.tar.gz
Algorithm Hash digest
SHA256 abf98d67aa9dd65cf1643d8f1ee581d25150c3844e7a7cb2ea0d985e9102bab1
MD5 414d7114327fa0cdc0015f533e92d940
BLAKE2b-256 1e5e4883935823e37d19ba537da739e192d13d5bc0dbcef5963ee853db978f9d

See more details on using hashes here.

Provenance

The following attestation bundles were made for barscan-0.2.2.tar.gz:

Publisher: release.yml on shimpeiws/barscan

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file barscan-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: barscan-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 43.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for barscan-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 8875b78a1ee5770d17852eb6ac3f845dffa7a8e94f863289ed6143da8be7176e
MD5 c51d06d3fe7b235797d5d15360da5305
BLAKE2b-256 6b49f0bce83a1962216b9a4edbd57ed82776adacccadf16f1af9ac63b1271f91

See more details on using hashes here.

Provenance

The following attestation bundles were made for barscan-0.2.2-py3-none-any.whl:

Publisher: release.yml on shimpeiws/barscan

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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