Skip to main content

Native Python PTSL (Pro Tools Scripting Library) RPC interface

Project description

Lint and Test codecov Documentation Status GitHub last commit

Pro Tools Version - 2025.10.0 PTSL Version - 2025.10.0

py-ptsl

Native Python PTSL (Pro Tools Scripting Library) RPC interface

Important Notice!

This software is developed by enthusiasts and is not a work of or supported by Avid. Developers who wish to contribute to this project should obtain the PTSL SDK from Avid's Developer site for the most current documentation and protobuf source files.

Example

See the examples directory for scripts demonstrating how to use the client.

  • session_info.py - This example prints a list of gettable properties from the currently-open session.
  • print_tracks.py - This example prints a list of every track in the currently-open session, including state information like selection, mute and solo state, track color and track ID.
  • make_session.py - Creates a new session interactively from the terminal.
  • pt_set.py - Allows several session setup options to be set from the terminal.
  • pt_pasteboard.py - Demonstrates triggering cut/copy/paste actions.
  • toolshell.py - Implements a command line interface for Pro Tools.

Sending Commands To Pro Tools with the Engine class

The Engine class exposes ptsl commands with a method call interface.

from ptsl import open_engine

with open_engine(company_name="MY_COMPANY", application_name="MY_TOOL") as engine:
    session_name = engine.session_name()

Sending Commands to Pro Tools from the Command Line

The module implements a main function that can be called from the shell. Pass request JSON to the standard input and any response will be passed to standard output.

bash-3.2$ poetry run python3 -m ptsl GetTrackList <<JSON 
{"pagination_request": {
  "limit": 100, "offset": 0
  },
"track_filter_list": [
  {"filter": 0, "is_inverted": false}
  ]
}
JSON
{'pagination_response': {'total': 4, 'offset': 0, 'limit': 100}, 'track_list':
[{'name': 'Au dio 1', 'type': 'TT_Audio', 'format': 'TF_Mono', ...
bash-3.2$ poetry run python3 -m ptsl -n GetPTSLVersion
{"version": 2025}

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

py_ptsl-601.0.1.tar.gz (92.7 kB view details)

Uploaded Source

Built Distribution

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

py_ptsl-601.0.1-py3-none-any.whl (121.7 kB view details)

Uploaded Python 3

File details

Details for the file py_ptsl-601.0.1.tar.gz.

File metadata

  • Download URL: py_ptsl-601.0.1.tar.gz
  • Upload date:
  • Size: 92.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for py_ptsl-601.0.1.tar.gz
Algorithm Hash digest
SHA256 7c139171ca78e7588161e8d8cd25111b88205bd74a6ab8424d9e47bf849b7d0c
MD5 60703b75b4325e9837ab9d3a1c576419
BLAKE2b-256 acf35f15ebab27f850ed705db4b1ab3043a232ca6b47796b515c76b0e4c01089

See more details on using hashes here.

Provenance

The following attestation bundles were made for py_ptsl-601.0.1.tar.gz:

Publisher: python-publish.yaml on iluvcapra/py-ptsl

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

File details

Details for the file py_ptsl-601.0.1-py3-none-any.whl.

File metadata

  • Download URL: py_ptsl-601.0.1-py3-none-any.whl
  • Upload date:
  • Size: 121.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for py_ptsl-601.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ed543ca77668863b9d377d14029c4af778d2a1cad1d7506e3ad388467305ae52
MD5 90a1cbe363bb04ed0e8dbf4527c78a79
BLAKE2b-256 037b6def2962a7baaa71a8409410db7a82937578035591918315925cacf8060c

See more details on using hashes here.

Provenance

The following attestation bundles were made for py_ptsl-601.0.1-py3-none-any.whl:

Publisher: python-publish.yaml on iluvcapra/py-ptsl

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