Skip to main content

Your Plex, your way

Project description

Plexy

Your Plex, your way

Latest Version

tests

License

Info

Plexy is a command line tool to save your watching preferences in Plex.

Dubbed or Original audio, it's up to you.

  • For Dubbed preference, Plexy will auto-select the audio track with your desired language. If no audio track is found, Plexy will auto-select the subtitle track with your desired language.
  • For Original preference, Plexy will auto-select the default/original audio track and the subtitle track in your desired language.

Priorities:

  • Commentary audio tracks have lower priority when selecting audio tracks
  • Closed caption and SDH subtitle tracks also have lower priority when selecting subtitles

To select Brazilian Portuguese language with original audio

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language pt-BR original

To select English language with dubbed audio

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language en dubbed

To select French language with original audio only for Game of Thrones

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language fr --title "Game of Thrones" original

To select German language with dubbed audio only for Mandalorian Season 2

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language fr --title "Mandalorian s02" dubbed

To select German language with dubbed audio only for Game of Thrones, season 3 and episode 9

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language fr --title "Game of Thrones s03e09" dubbed

To select Spanish language with dubbed audio only for all Matrix movies and the first Avatar movie

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language es --title "Matrix" --title "Avatar (2009)" dubbed

To select Portuguese language with original audio for everything added to your libraries in the last week

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language pt --newer 1w original

To select Brazilian Portuguese language with original audio for everything added to your "Movie" library before the last week

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --library Movie --language pt-BR --older 1w original

You can also select or exclude tracks based on their codec/format. For instance, you have a Chromecast with Google TV which doesn't support Dolby TrueHD audio codec. You can exclude this codec when saving your preferences:

>> plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language pt-BR -A truehd original

And print the full summary of changes:

>> plexy --url http://mylocalplex:32400 --token ABCDEFGHIJ1234567890 preferences -f -l en --title "The Matrix (1999)" original
Configuring watching preferences  [####################################]  100%
1 movie changed out of 1 selected movie
The Matrix (1999) changed from pt-BR: Português (SRT External) to no subtitles

You can also define your configuration options in a json or yaml file:

url: http://myplexserver:32400
token: ABCDEFGHIJ1234567890
preferences:
  library:
    - Movies
    - TV Shows
  excluded_subtitle_codec:
    - eia_608
  full_summary: True
  language: pt-BR
  watching_preference: original

By default, plexy will load config.json, config.yaml or config.yml file from the folders:

  • Mac OS: ~/Library/Preferences/plexy
  • Linux: ~/.config/plexy/
  • Windows: C:\Users\<USER>\AppData\Local\plexy\plexy

And then update the configuration with data from plexy.json, plexy.yaml or plexy.yml in the current working directory.

You can pass the configuration to use with the --config parameter:

>> plexy --config myconfig.yml preferences
Configuring watching preferences  [####################################]  100%
1 movie changed out of 1 selected movie
The Matrix (1999) changed from pt-BR: Português (SRT External) to no subtitles

All available CLI options:

>> plexy --url <PLEX_URL> --token <USER_TOKEN> preferences --help
Usage: plexy preferences [OPTIONS] {original|dubbed}

  Your watching preferences

  Dubbed prefers an audio track with the desired language.
  Original prefers the original audio and an additional subtitle track if the audio is not in the desired language.

Options:
  -L, --library TEXT              Library to be used. e.g: Movies, Shows.
  -t, --title TITLE               Filter for titles in your library. It could refer to a movie, a
                                  show, a season or an episode. e.g: Avatar, The Matrix (1999),
                                  The Boys s2, Chernobyl s01e03, Game of Thrones (2011) s03e09
  -l, --language LANGUAGE         Desired watching language as IETF code, e.g.: en, pt-BR.
  -a, --audio-codec [dca|aac|ac3|eac3|truehd|flac|mp2|mp3|vorbis|pcm]
                                  Accepted audio codec.
  -A, --excluded-audio-codec [dca|aac|ac3|eac3|truehd|flac|mp2|mp3|vorbis|pcm]
                                  Excluded audio codec.
  -s, --subtitle-codec [srt|pgs|vobsub|ass|mov_text|eia_608|dvb_subtitle]
                                  Accepted subtitle codec.
  -S, --excluded-subtitle-codec [srt|pgs|vobsub|ass|mov_text|eia_608|dvb_subtitle]
                                  Excluded subtitle codec.
  -n, --newer-than AGE            Filter movies/episodes newer than AGE, e.g. 12h, 1w2d
  -o, --older-than AGE            Filter movies/episodes older than AGE, e.g. 12h, 1w2d
  -f, --full-summary              Print the full summary of changed preferences.
  --skip-watching                 Skip movies/episodes that watch is in progress.
  --keep-selected-audio           Do not change the selected audio. Useful when using original
                                  watching preference.
  --keep-selected-subtitle        Do not change the selected subtitle.
  --force-subtitles               Select subtitles, even when the audio already matches the
                                  desired language.
  --debug                         Print useful information for debugging and for reporting bugs.
  --help                          Show this message and exit.

Using Docker

docker run -it --rm plexy --url http://mylocalplex:32400 --token ABCDEF1234567890 preferences --language pt-BR -A truehd original

Installation

Plexy can be installed as a regular python module by running:

$ [sudo] pip install plexy

For a better isolation with your system you should use a dedicated virtualenv or install for your user only using the --user flag.

Dependencies

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

plexy-0.1.5.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

plexy-0.1.5-py3-none-any.whl (13.7 kB view details)

Uploaded Python 3

File details

Details for the file plexy-0.1.5.tar.gz.

File metadata

  • Download URL: plexy-0.1.5.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1022-azure

File hashes

Hashes for plexy-0.1.5.tar.gz
Algorithm Hash digest
SHA256 8787a8a6f41754dce1375ca3979da87ecfa92fbe10a52d9c8832fc09cbacfccf
MD5 5e17c9d3e0dbf68a3e2953207a42a659
BLAKE2b-256 54f22e078c7c0a31435f88f604652add87c1f79963f9fe6911e9879a94bbe851

See more details on using hashes here.

File details

Details for the file plexy-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: plexy-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 13.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.4 Linux/6.5.0-1022-azure

File hashes

Hashes for plexy-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 9a06337108fb14c760bb1ec3f1e5efe76603c38e3e3bfd842c1aa162ddf175f5
MD5 f0eecd2b9779994a672326c10fac364f
BLAKE2b-256 0e107dc9e59b5ea614d23233449250d68f61a5ad8c26338370ea992acc77598e

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