Skip to main content

Enhanced PreQL for common ETL needs.

Project description

Simple Declarative Data Pipelines

Combine the simplicity of Trilogy with the modern data stack.

Compile your models to ETL scripts to run on demand. Rebuild, run, and test easily.

Translates 'Persist' statements in Trilogy to scheduled ETL jobs.

Currently supported backends:

  • DBT

[!WARNING] This is a work in progress. Please report any issues or feature requests.

Flags

--optimize=X - Any CTE used at least X times in calculating final model outputs will be materialized for reuse.

[!TIP] Don't worry about optimizing your temp table graph ever again - write your final tables and let TrilogyT handle the rest.

Install

pip install pytrilogyt

How to Run

preqlt <preql_path> <dbt_project_root_path> --run

trilogyt dbt/models/core/ ./dbt bigquery --run

Each source preql file will be built into a separate DBT sub folder with one model per persist statement.

17:12:37  Running with dbt=1.7.4
17:12:38  Registered adapter: bigquery=1.7.2
17:12:38  Found 4 models, 4 tests, 0 sources, 0 exposures, 0 metrics, 447 macros, 0 groups, 0 semantic models
17:12:38
17:12:40  Concurrency: 4 threads (target='dev')
17:12:40
17:12:41  1 of 4 START sql view model dbt_test.customers ................................. [RUN]
17:12:41  2 of 4 START sql table model dbt_test.customers_preql_preqlt_gen_model ......... [RUN]
17:12:41  3 of 4 START sql table model dbt_test.my_first_dbt_model ....................... [RUN]
17:12:42  1 of 4 OK created sql view model dbt_test.customers ............................ [CREATE VIEW (0 processed) in 1.09s]
17:12:43  3 of 4 OK created sql table model dbt_test.my_first_dbt_model .................. [CREATE TABLE (2.0 rows, 0 processed) in 2.78s]
17:12:43  4 of 4 START sql view model dbt_test.my_second_dbt_model ....................... [RUN]
17:12:44  2 of 4 OK created sql table model dbt_test.customers_preql_preqlt_gen_model .... [CREATE TABLE (100.0 rows, 4.3 KiB processed) in 3.55s]
17:12:44  4 of 4 OK created sql view model dbt_test.my_second_dbt_model .................. [CREATE VIEW (0 processed) in 1.10s]
17:12:44
17:12:44  Finished running 2 view models, 2 table models in 0 hours 0 minutes and 6.37 seconds (6.37s).
17:12:45  
17:12:45  Completed successfully
17:12:45
17:12:45  Done. PASS=4 WARN=0 ERROR=0 SKIP=0 TOTAL=4
customers: success
my_first_dbt_model: success
customers_preql_preqlt_gen_model: success
my_second_dbt_model: success

From IO

Write-Output """constant x <-5; persist into static as static select x;""" | trilogyt <output_path> bigquery

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

pytrilogyt-0.0.6.tar.gz (12.0 kB view details)

Uploaded Source

Built Distribution

pytrilogyt-0.0.6-py3-none-any.whl (13.6 kB view details)

Uploaded Python 3

File details

Details for the file pytrilogyt-0.0.6.tar.gz.

File metadata

  • Download URL: pytrilogyt-0.0.6.tar.gz
  • Upload date:
  • Size: 12.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for pytrilogyt-0.0.6.tar.gz
Algorithm Hash digest
SHA256 6759ef182972313f64d0440b6c28a24b1fa9200caf784756775853e8e8c8dfa9
MD5 fc1687a99d66ca6fd9a2d5f8301b8ae2
BLAKE2b-256 a2d283c890262171bf2b42dc468d374f4caa0c131ab046d88752816440ff4c2c

See more details on using hashes here.

File details

Details for the file pytrilogyt-0.0.6-py3-none-any.whl.

File metadata

  • Download URL: pytrilogyt-0.0.6-py3-none-any.whl
  • Upload date:
  • Size: 13.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for pytrilogyt-0.0.6-py3-none-any.whl
Algorithm Hash digest
SHA256 36af13c7c366b41a8aa9d354ce9f94c7d04edf4f72e2d530f7ac6a1298fc3b84
MD5 16c2ae1b1daa9b17972ecc8dd3e460a5
BLAKE2b-256 455a8092244c50d3f88280fe0876fcc7c210371bd85e124c32a4ebe06e260f11

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