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.1.tar.gz (11.7 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.1-py3-none-any.whl (12.1 kB view details)

Uploaded Python 3

File details

Details for the file python-mpv-jsonipc-1.2.1.tar.gz.

File metadata

  • Download URL: python-mpv-jsonipc-1.2.1.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.2

File hashes

Hashes for python-mpv-jsonipc-1.2.1.tar.gz
Algorithm Hash digest
SHA256 96f4864158fe3a35e80a88ef7bb2ddae14b899e8ec5d2d728687c7fb51c807cc
MD5 b704beda44b3a1fcfa5081c425603ff6
BLAKE2b-256 c12953914dc0c9f06e5223536f180efdab14b400b85526433da62e7371c2c81a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for python_mpv_jsonipc-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a28dd859e259b78c09de5102f0076e27dd5474c6a8644e19b6a6169ffc4dc0a3
MD5 c36a37dcca4be08a6cd423d19d9df4c2
BLAKE2b-256 d04ffd53b9e82abaeef2a36d5974e02b0b6597f0e2bc14d9988cb930d9ef3475

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