Skip to main content

Control various media players from a single command line interface.

Project description

player_do provides a simple command line interface to control whatever media player is running on your computer. It has been designed for and tested on Linux.

It is designed to allow you to configure the media buttons on your keyboard (play, pause, next etc.) to Do The Right Thing without having to change anything if you switch to a different media player.

It also includes commands install_gnome, install_mate, install_gnome3, and install_cinnamon to help set up keyboard shortcuts initially on GNOME2/Mate/GNOME3/Cinnamon. It can, however, be used with any system where you can map keyboard shortcuts to commands.

The currently supported media players can be seen by running player_do --help. Those that have been tested include the following:

  • Audacious

  • Amarok

  • Banshee

  • Clementine

  • cmus

  • Exaile

  • Guayadeque

  • moc

  • MPD (configurable using MPD_HOST and MPD_PORT environment variables like mpc)

  • pianobar

  • Quodlibet

  • Rhythmbox (needs MPRIS plugin installed and enabled)

  • shell-fm (0.8 and later)

  • VLC (2.0 and later)

  • Firefox, Chrome (when playing some media like videos and podcasts)

Many other players will be supported due to support for the MPRIS DBUS protocol, without a specific backend. If you only need support for those players, consider using MPRIS-remote or playerctl.

To add more supported programs, see the existing code in the backends directory. Patches gratefully received!

Installation

You need Python 3.8 or later, Python 3.12 or later recommended as I test on that. We recommend the use of uv to install as below:

uv python install 3.12
uv tool install playerdo --python 3.12

This should install everything for you.

Installation using pipx

On older systems or if uv is not available, you can install using pipx to install it into its own virtualenv, using your standard system Python 3, with “system” libraries available (due to the DBUS requirementw):

pipx install playerdo --system-site-packages --python `which python3`

You will also need to install Python DBUS bindings. We recommend doing this at the system level. On Debian-like systems this is usually done with one of the following packages:

python-dbus
python3-dbus

An alternative to system-level Python DBUS is to use pipx to install them:

pipx inject playerdo dbus-python

(If an appropriate binary wheel for dbus is not found, the above may require development packages to be installed, including libglib2.0-dev and libdbus-1-dev and Python development headers).

After installation, you can use player_do test to ensure everything expected is available. It’s normal to see error messages relating to players that you do not use or have installed.

Usage

Control the currently active player using commands like:

player_do playpause
player_do next

For all commands and other options, see:

player_do --help

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

playerdo-2.2.tar.gz (17.4 kB view details)

Uploaded Source

Built Distribution

playerdo-2.2-py3-none-any.whl (19.1 kB view details)

Uploaded Python 3

File details

Details for the file playerdo-2.2.tar.gz.

File metadata

  • Download URL: playerdo-2.2.tar.gz
  • Upload date:
  • Size: 17.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.4.20

File hashes

Hashes for playerdo-2.2.tar.gz
Algorithm Hash digest
SHA256 b40d3fff715f1a88ff3750ae656c232aad30348520c4437842061f8602bfbfb9
MD5 d2ba78c6061c7d23e9f706e7fdc95568
BLAKE2b-256 49e6ac8259dca795c6a340ebaaa26357ecaa9f8f0525bbce698a717abff4e5bd

See more details on using hashes here.

File details

Details for the file playerdo-2.2-py3-none-any.whl.

File metadata

  • Download URL: playerdo-2.2-py3-none-any.whl
  • Upload date:
  • Size: 19.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.4.20

File hashes

Hashes for playerdo-2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f65c42b74fd031e4da2c156fcd71f67bdb8de812d50b311da9d8fbad10f4850b
MD5 0f4a1c53ff09a7e6840d27c8835472b1
BLAKE2b-256 092f58b671b9170598b9b921a895107644ab70958fe9dbc25ce13ba3ebab70fc

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