Skip to main content

Python API to MPV using JSON IPC

Project description

Python MPV JSONIPC

This implements an interface similar to python-mpv, but it uses the JSON IPC protocol instead of the C API. This means you can control external instances of MPV including players like SMPlayer, and it can use MPV players that are prebuilt instead of needing libmpv1. It may also be more resistant to crashes such as Segmentation Faults, but since it isn't directly communicating with MPV via the C API the performance will be worse.

Please note that this only implements the subset of python-mpv that is used by plex-mpv-shim and jellyfin-mpv-shim. Other functionality has not been implemented.

Installation

sudo pip3 install python-mpv-jsonipc

Basic usage

Create an instance of MPV. You can use an already running MPV or have the library start a managed copy of MPV. Command arguments can be specified when initializing MPV if you are starting a managed copy of MPV.

Please also see the API Documentation.

from python_mpv_jsonipc import MPV

# Uses MPV that is in the PATH.
mpv = MPV()

# Use MPV that is running and connected to /tmp/mpv-socket.
mpv = MPV(start_mpv=False, ipc_socket="/tmp/mpv-socket")

# Uses MPV that is found at /path/to/mpv.
mpv = MPV(mpv_location="/path/to/mpv")

# After you have an MPV, you can read and set (if applicable) properties.
mpv.volume # 100.0 by default
mpv.volume = 20 

# You can also send commands.
mpv.command_name(arg1, arg2)

# Bind to key press events with a decorator
@mpv.on_key_press("space")
def space_handler():
    pass

# You can also observe and wait for properties.
@mpv.property_observer("eof-reached")
def handle_eof(name, value):
    pass

# Or simply wait for the value to change once.
mpv.wait_for_property("duration")

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

python_mpv_jsonipc-1.2.2.tar.gz (11.6 kB view details)

Uploaded Source

Built Distribution

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

python_mpv_jsonipc-1.2.2-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

Details for the file python_mpv_jsonipc-1.2.2.tar.gz.

File metadata

  • Download URL: python_mpv_jsonipc-1.2.2.tar.gz
  • Upload date:
  • Size: 11.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.5

File hashes

Hashes for python_mpv_jsonipc-1.2.2.tar.gz
Algorithm Hash digest
SHA256 9343b78e0eb8814e92c1927d024c6b0ef25c677ed74531bc90bd395b462836d4
MD5 883e76f55e3197887e394d963d14d4c5
BLAKE2b-256 afac59a3d4a40475aac5cf951fcad8c45f0851067318228dc8aefbb567c99e1d

See more details on using hashes here.

File details

Details for the file python_mpv_jsonipc-1.2.2-py3-none-any.whl.

File metadata

File hashes

Hashes for python_mpv_jsonipc-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 b90ba3bc29291179ab2d946b3c244d17a8cda0e914f468fcbb28c8f635411832
MD5 de536f73f7bd85e848c1d8f5074574ed
BLAKE2b-256 8fcf1a6ba7e4572717637c91032f52a599167906244f6e27751414438e68f283

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