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.42.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.42-py3-none-any.whl (6.5 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for morphql-0.1.42.tar.gz
Algorithm Hash digest
SHA256 461b1eaf00a8931475008801ff99b1ccef0e767cf3b58f44b8472a368739e4ec
MD5 3fde02d61b9f4ac013a2307911c5c28b
BLAKE2b-256 e0a01194130faa710d2f1b1cd028d36e1771f166b39e71076aa31dc9abe29c5c

See more details on using hashes here.

Provenance

The following attestation bundles were made for morphql-0.1.42.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.42-py3-none-any.whl.

File metadata

  • Download URL: morphql-0.1.42-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.12

File hashes

Hashes for morphql-0.1.42-py3-none-any.whl
Algorithm Hash digest
SHA256 761db96ae076bb3773f215d5b8682b56d3e4742b4187ca14a78e4c6e45be6639
MD5 a394f265b75cedbffba53dc3156b4199
BLAKE2b-256 0b7ce114ea07fbe5e988ce8192e41e10feccf825b82cde1cc6c17267c8755f36

See more details on using hashes here.

Provenance

The following attestation bundles were made for morphql-0.1.42-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