Skip to main content

Youtube-based Karaoke machine for Raspberry Pi, OSX, Windows, and Linux

Project description

PiKaraoke

Image

PiKaraoke is a cross-platform karaoke server that brings the professional "KTV" experience to your home. It transforms your computer or Raspberry Pi into a dedicated karaoke station with a full-screen player and an instant web interface. Guests can join by simply scanning a QR code—no app downloads required—to browse your local library, manage the queue, and access countless karaoke hits from YouTube.

  • 📱 Instant Mobile Remote: Search and queue songs from any smartphone—just scan and sing.
  • 📺 Dedicated Player: High-performance splash screen that can be opened on any web browser for a true karaoke room feel.
  • 🌐 YouTube & Local Media: Play your own files or access more from the web.
  • 🎹 Live Pitch Shifting: Adjust the key of any song to match your vocal range.
  • 🛠️ Admin Control: Manage the queue and settings via a password-protected admin mode.
  • 🎯 Hyper-accurate vocal performance scoring system: (not really, it's random. But kind of fun!)
  • 🐧 Lightweight & Versatile: Runs anywhere from a basic Raspberry Pi to a high-end PC.

Love PiKaraoke? This project is independently maintained and free for everyone to enjoy. If PiKaraoke has made your parties better and you'd like to help keep the project alive and growing, feel free to buy me a coffee!

Buy Me A Coffee

Conventional Commits

Table of Contents

Supported Devices / OS / Platforms

  • OSX
  • Windows
  • Linux
  • Raspberry Pi 4 or higher (Pi3 works ok with overclocking)

Quick Install

For a streamlined installation that handles all dependencies (uv, ffmpeg, deno) and installs PiKaraoke, run the following in your terminal:

Linux & macOS

curl -fsSL https://raw.githubusercontent.com/vicwomg/pikaraoke/master/build_scripts/install/install.sh | bash

Windows (PowerShell)

irm https://raw.githubusercontent.com/vicwomg/pikaraoke/master/build_scripts/install/install.ps1 | iex

After installation, you can launch pikaraoke from the command line with pikaraoke or from a desktop shortcut. Re-running the above command will update a previous pikaraoke installation to the latest version.

Manual installation (advanced users)

Prerequisites

  • A modern web browser (Chrome/Chromium/Edge recommended)
  • Python 3.10 or greater: Python downloads
  • FFmpeg (preferably a build with lib-rubberband for transposing): FFmpeg downloads
  • A js runtime installed to your PATH. Node.js is most common, Deno is probably easiest for non-developers.

Install the pikaraoke package

We recommend installing pikaraoke via uv.

uv tool install pikaraoke

You may alternately use the standard python pip install pikaraoke installer if you are familiar with virtual environments or you are not concerned with global package isolation.

Usage

Run pikaraoke from the command line with:

pikaraoke

Launches the player in "headed" mode via your default browser. Scan the QR code to connect mobile remotes. Use pikaraoke --headless to run as a background server for external browsers.

See the help command pikaraoke --help for available options.

To upgrade to the latest version of pikaraoke, run:

uv tool upgrade pikaraoke

Docker instructions

Run PiKaraoke in Docker using the command below. Note the requirements for port mapping, LAN IP specification, and persistent volume mounts (set to ~/.pikaraoke in the example for simplicity):

docker run -p 5555:5555 \
  -v ~/pikaraoke-songs:/app/pikaraoke-songs \
  -v ~/.pikaraoke:/home/pikaraoke/.pikaraoke \
  vicwomg/pikaraoke:latest \
  -u http://<YOUR_LAN_IP>:5555

For more information and a configurable docker-compose example, see official Dockerhub repo

Screenshots

pikaraoke-nowplaying pikaraoke-queue pikaraoke-browse pikaraoke-search1 pikaraoke-search2 pikaraoke-tv2

Developing pikaraoke

The Pikaraoke project utilizes uv for dependency management and local development.

  • Install uv
  • Git clone this repo

From the pikaraoke directory:

# install dependencies and run pikaraoke from local code
uv run pikaraoke

See the Pikaraoke development guide for more details.

Troubleshooting and guides

See the TROUBLESHOOTING wiki for help with issues.

There are also some great guides on the wiki to running pikaraoke in all manner of bizarre places including Android, Chromecast, and embedded TVs!

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

pikaraoke-1.18.3.tar.gz (13.2 MB view details)

Uploaded Source

Built Distribution

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

pikaraoke-1.18.3-py3-none-any.whl (13.2 MB view details)

Uploaded Python 3

File details

Details for the file pikaraoke-1.18.3.tar.gz.

File metadata

  • Download URL: pikaraoke-1.18.3.tar.gz
  • Upload date:
  • Size: 13.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pikaraoke-1.18.3.tar.gz
Algorithm Hash digest
SHA256 0c6ae02ea368343363a45b581c7346fce1132c2eeff16125361bbda1c9d873e8
MD5 2a14b7f230af15d3d1b771b04a333dcf
BLAKE2b-256 e1bfa7b47a4f965f54cee605cc87cb9688b22449cb15690d106e414558b12c64

See more details on using hashes here.

Provenance

The following attestation bundles were made for pikaraoke-1.18.3.tar.gz:

Publisher: release-please.yml on vicwomg/pikaraoke

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

File details

Details for the file pikaraoke-1.18.3-py3-none-any.whl.

File metadata

  • Download URL: pikaraoke-1.18.3-py3-none-any.whl
  • Upload date:
  • Size: 13.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pikaraoke-1.18.3-py3-none-any.whl
Algorithm Hash digest
SHA256 fb58d4055372d5a34a4fce857f9f3ffe42e59ad0f73937060297baed326ed826
MD5 27290f66392993cd0a6be1f40f6de873
BLAKE2b-256 229c5eb31003a0158e6a54b31a1644146f821c8503800b5b1b5f583ac8f8143b

See more details on using hashes here.

Provenance

The following attestation bundles were made for pikaraoke-1.18.3-py3-none-any.whl:

Publisher: release-please.yml on vicwomg/pikaraoke

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