Skip to main content

A simple OLAP library.

Project description

Installation

Besides the main contents of the package, you can install the optional dependencies for the backend driver of your choice:

  • tesseract-olap[clickhouse]
    Installs the dependency needed to enable the use of the tesseract_olap.backend.clickhouse module.

Getting started

In its most basic form, the tesseract-olap package provides you with a way to translate OLAP-type queries into request statements that a data backend can understand and execute safely. The results obtained through the execution of server methods are python objects, and as such, can be used in any way the language allows.

# example.py

from tesseract_olap.backend.clickhouse import ClickhouseBackend
from tesseract_olap import OlapServer

backend = ClickhouseBackend("clickhouse://user:pass@localhost:9000/database")
server = OlapServer(backend=backend, schema="./path/to/schema.xml")

def get_data():
    # First you create an ordered representation of the intent for data
    request = DataRequest.new("cube_name", {
      "drilldowns": ["Time", "Country"],
      "measures": ["Units", "Price"],
    })

    # This step performs the validation of the request against the schema
    query = DataQuery.from_request(server.schema, request)

    # The context manager establishes the connection with the backend
    with server.session() as session:
        # .fetch() methods perform the request against the server.
        # There are three methods depending on the shape you want the data:
        # result = session.fetch(query)
        # result = session.fetch_dataframe(query)
        result = session.fetch_records(query)
    
    return result.data

if __name__ == "__main__":
    get_data()

The server instance can then be used in other programs as the data provider, for simple (like data exploration) and complex (like data processing) operations.


© 2022 Datawheel, LLC.
This project is licensed under 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

tesseract_olap-0.12.1.tar.gz (62.8 kB view details)

Uploaded Source

Built Distribution

tesseract_olap-0.12.1-py3-none-any.whl (77.3 kB view details)

Uploaded Python 3

File details

Details for the file tesseract_olap-0.12.1.tar.gz.

File metadata

  • Download URL: tesseract_olap-0.12.1.tar.gz
  • Upload date:
  • Size: 62.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.6.59

File hashes

Hashes for tesseract_olap-0.12.1.tar.gz
Algorithm Hash digest
SHA256 3272175e01f20e8609812bd70b5bd2c5190d70ce419d025e400d7172b4eb7299
MD5 85126a280c15042e2f925f2dbe16cfc4
BLAKE2b-256 e1227c4c504c023e4476deac3d08ef303b93d343b31e22cb4278a1b702a22c36

See more details on using hashes here.

File details

Details for the file tesseract_olap-0.12.1-py3-none-any.whl.

File metadata

  • Download URL: tesseract_olap-0.12.1-py3-none-any.whl
  • Upload date:
  • Size: 77.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.12.7 Linux/6.6.59

File hashes

Hashes for tesseract_olap-0.12.1-py3-none-any.whl
Algorithm Hash digest
SHA256 af174a3439b34222dd19308ad066f1a786c16f8c0382895f282cc041c9d17ede
MD5 89a265d6b037b292df3e340cb1791efd
BLAKE2b-256 34a7770c2df85b967037224d5477bdc155cb032f97530cf44d3d250391e31496

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