Skip to main content

Public Trilogy models.

Project description

trilogy-public-models

Overview

This repository contains semantic models describing public datasets as Trilogy data models.

You can use this to quickly get started with Trilogy, or just as a place to find fun data to explore.

Installation

pip install trilogy-public-models

Examples

This repository also contains a examples/ folder, which can be browsed for in-depth code examples.

Quickstart

This will import and set up a duckdb engine with a SF .5 environment.

from trilogy_public_models import data_models
from trilogy_public_models import get_executor

executor = get_executor("duckdb.tpc-ds")

QA_1 ="""
select 
    store_sales.date.year, 
    count(store_sales.customer.id)->customer_count
order by 
    store_sales.date.year desc ;
"""  # noqa: E501

results = executor.execute_text(QA_1)

for row in results[0].fetchall():
    print(row)

Advanced Usage

This example assumes you are querying Bigquery Datasets.

To utilize a model, instantiate a standard Trilogy executor (in this case, a bigquery client) and then pass in one of the existing environments from this package into the environment argument.

That will enable you to run queries against the semantic model.

from google.auth import default
from google.cloud import bigquery
from trilogy.executor import Executor, Dialects
from sqlalchemy.engine import create_engine

from trilogy_public_models.bigquery import google_search_trends
from trilogy_public_models import get_executor


# use default auth
exec = get_executor('google_search_trends')

# or provide client explicitly
# if using more complicated auth
project, auth = default()
bq_client = bigquery.Client(auth, project)

engine = create_engine(f"bigquery://{project}?user_supplied_client=True",
                       connect_args={'client': bq_client})

exec = Executor(
    dialect=Dialects.BIGQUERY, engine=engine,
    environment=google_search_trends
)

results = exec.execute_text("""
SELECT 
	trends.term,
	trends.rank,
	trends.week,
	trends.refresh_date,
WHERE
    trends.week > '2023-01-01'
    and trends.refresh_date = '2023-02-22'
    and trends.rank < 10
ORDER BY 
    trends.week desc,
    trends.rank asc
limit 100;

""")

# you can execute multiple queries separate by a semicolon
# so our results will be in the first element of the arra
for row in results[0]:
    print(row)

You can access all models through the data_model object:

from trilog_public_models import data_models

for k, v in data_models.items():
    print(k)
    _ = v.environment # environment

Combining Models

Trilogy supports combining multiple environments into a single environment. This enables simplified querying of universal concepts, like looking up StackOverflow links embedded in Github commits, or merging GPS data across different domains.

Use the standard trilogy toolkit of merges to do this.

Contributing

Model setup

All models should be in a double nested directory; first the platform and then the semantic label of the model

Models should have the following

  • entrypoint.preql
  • README.md

Model Tests

All models will be imported and verified. Validation methods will depend on the defined backend.

All models require that the datasets being shared with the preql validation account.

Current verifications:

  • model imports successfully
  • datasource bindings exist
  • datasource to concept mappings are appropriately typed
  • concept relations are consistently typed

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

trilogy_public_models-0.1.6.tar.gz (32.8 kB view details)

Uploaded Source

Built Distribution

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

trilogy_public_models-0.1.6-py3-none-any.whl (59.8 kB view details)

Uploaded Python 3

File details

Details for the file trilogy_public_models-0.1.6.tar.gz.

File metadata

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

File hashes

Hashes for trilogy_public_models-0.1.6.tar.gz
Algorithm Hash digest
SHA256 fe14f3660d4f90876b1c9fa4a7b43c333af95d5e540a7aec531beaa6db84dee6
MD5 551222276759a71a2cf1c8a67abb432e
BLAKE2b-256 f9cf725e4aeb43b3755baff04b697a3a2a2447929e4075166ac5376cbc5d48a5

See more details on using hashes here.

Provenance

The following attestation bundles were made for trilogy_public_models-0.1.6.tar.gz:

Publisher: pythonpublish.yml on trilogy-data/trilogy-public-models

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

File details

Details for the file trilogy_public_models-0.1.6-py3-none-any.whl.

File metadata

File hashes

Hashes for trilogy_public_models-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 eb0a7a988ba87a138dc3f12fc15d8a3152e85aa30d9b7d1778ce7c8d790a378b
MD5 2f8b6d8fa9ba9552b70aaa5d6cbec573
BLAKE2b-256 691bf8ce9bbdd6b303ceee152d4fd3aa2074a54e68c0809dd49cc6e6610bbef1

See more details on using hashes here.

Provenance

The following attestation bundles were made for trilogy_public_models-0.1.6-py3-none-any.whl:

Publisher: pythonpublish.yml on trilogy-data/trilogy-public-models

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