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

Uploaded Python 3

File details

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

File metadata

  • Download URL: morphql-0.1.35.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.35.tar.gz
Algorithm Hash digest
SHA256 9b4859533772af5c33bae8d00fedf2039e2bd23bd232242567da5d4a25e1df54
MD5 b454cefa9f48dda98911eb6ee7979da0
BLAKE2b-256 4ef49351487cb920a318c746d8442dc7ad97fcff2564e1a9782e419ea3b451ec

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: morphql-0.1.35-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.35-py3-none-any.whl
Algorithm Hash digest
SHA256 758d4a178fb9ed36fb621b0ab6443e8f19aa82bb1a78da9451a9ae62c9990f7e
MD5 7e81d42a6862adba8f9bfdaeeaa7eb11
BLAKE2b-256 ab35eac477839fcf03300ce162daf5cb365335f1527f7616f113cb7216ac0437

See more details on using hashes here.

Provenance

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