Skip to main content

Python client for MorphQL — transform data with declarative queries.

Project description

morphql · Python client

Python client for MorphQL — a declarative DSL for structural data transformation.

Delegates execution to the MorphQL CLI or a running MorphQL server. Zero external dependencies. Python >= 3.8.

Installation

pip install morphql

Quick start

from morphql import MorphQL

# One-shot static call (CLI provider)
result = MorphQL.execute(
    "from json to json transform set name = source.firstName",
    data={"firstName": "Alice"},
)
print(result)  # {"name":"Alice"}

# From a .morphql file
result = MorphQL.execute_file("transform.morphql", data={"x": 1})

# Instance with preset defaults (server provider)
morph = MorphQL(provider="server", server_url="http://localhost:3000")
result = morph.run("from json to json transform set x = source.x", data={"x": 42})
result = morph.run_file("transform.morphql", data={"x": 42})

Providers

Provider How it works
"cli" Runs morphql CLI via subprocess (default)
"server" POST {server_url}/v1/execute via urllib

Options

Option Default Env var
provider "cli" MORPHQL_PROVIDER
runtime "node" MORPHQL_RUNTIME
cli_path "morphql" MORPHQL_CLI_PATH
node_path "node" MORPHQL_NODE_PATH
qjs_path auto-resolved MORPHQL_QJS_PATH
cache_dir $TMPDIR/morphql MORPHQL_CACHE_DIR
server_url "http://localhost:3000" MORPHQL_SERVER_URL
api_key None MORPHQL_API_KEY
timeout 30 (seconds) MORPHQL_TIMEOUT

Priority: call kwarg > instance default > env var > hardcoded default.

API

Static

MorphQL.execute(query, data=None, **options) -> str
MorphQL.execute_file(query_file, data=None, **options) -> str

Instance

morph = MorphQL(**defaults)
morph.run(query, data=None, **options) -> str
morph.run_file(query_file, data=None, **options) -> str

data accepts str (JSON), dict, list, or None.

Exceptions

Situation Exception
query missing or empty ValueError
Query file not found FileNotFoundError
CLI exits with error RuntimeError
Server HTTP error RuntimeError
Server unreachable RuntimeError

Running tests

cd packages/python
PYTHONPATH=src python -m unittest discover tests/
# or with pytest:
pip install pytest
pytest

License

MIT

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

morphql-0.1.36.tar.gz (9.2 kB view details)

Uploaded Source

Built Distribution

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

morphql-0.1.36-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

Details for the file morphql-0.1.36.tar.gz.

File metadata

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

File hashes

Hashes for morphql-0.1.36.tar.gz
Algorithm Hash digest
SHA256 c6fe06bc008b3d14b5608181375457646b332830824eb64f88678e6edbf4a9b5
MD5 8cd569af6bcb82b07db0fdd4a890be3d
BLAKE2b-256 7e2cb47ae50617e77a34cf000a6fb72c612439fa582c80154803d8e1fa862eb4

See more details on using hashes here.

Provenance

The following attestation bundles were made for morphql-0.1.36.tar.gz:

Publisher: publish.yml on Hyperwindmill/morphql

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

File details

Details for the file morphql-0.1.36-py3-none-any.whl.

File metadata

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

File hashes

Hashes for morphql-0.1.36-py3-none-any.whl
Algorithm Hash digest
SHA256 8323da91c494dee59462a677ee390da18a9a85a57453fa241fc785ff75623134
MD5 7e612218751c36cbf5537fa54cf68529
BLAKE2b-256 b8657102e76f08fd1da426dc66c164eddbc521b393bd6b0e4132503d60fe30f9

See more details on using hashes here.

Provenance

The following attestation bundles were made for morphql-0.1.36-py3-none-any.whl:

Publisher: publish.yml on Hyperwindmill/morphql

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