Skip to main content

@themost-framework alternative for python

Project description

pycentroid

pycentroid logo

@themost-framework for Python

@themost-framework is a fully-featured end-to-end framework for building scalable data-driven web applications and services under node.js. It consists of a wide set of server-side libraries and client-side tools for helping developers creating scalable and configurable production environments. pycentroid is a @themost-framework alternative for python.

pycentroid.client

A client-side library of @themost-framework application for python

from typing import List
from pycentroid.client import ClientDataContext, ClientContextOptions
from pycentroid.query import select

async def get_products():
    context = ClientDataContext(ClientContextOptions('http://localhost:3000/api/'))
    # get products
    items: List = await context.model('Products').as_queryable().select(
            lambda x: select(id=x.id, name=x.name, product_model=x.model,)
        ).where(
            lambda x: x.category == 'Laptops'
        ).get_items()
    return items

Read more at pycentroid.client

pycentroid.query

A database-agnostic query module which for writing SQL expressions of any kind

from pycentroid.query import QueryExpression, QueryEntity, SqlFormatter, select


products = QueryEntity('ProductData')
query = QueryExpression(products).select(
        lambda x: select(id=x.id, name=x.name, price=round(x.price, 2))
    ).where(
        lambda x: round(x.price, 2) < 800 and x.category == 'Laptops'
    )
sql = SqlFormatter().format(query)
# sql > SELECT id,name,ROUND(price,2) AS price FROM ProductData WHERE ((ROUND(price,2)<800) AND (category='Laptops'))

pycentroid.data

A next-generation ORM data module for developing data-driven application and services.

from pycentroid.data.application import DataApplication
from os.path import abspath, join, dirname
APP_PATH = abspath(join(dirname(__file__), '..'))


async def main():
    app = DataApplication(cwd=APP_PATH)
    context = app.create_context()
    results = await context.model('Order').where(
        lambda x: x.orderedItem.category == 'Desktops'
        ).get_items()
    print(results)

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

pycentroid-1.1.6.tar.gz (59.7 kB view details)

Uploaded Source

Built Distribution

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

pycentroid-1.1.6-py3-none-any.whl (75.0 kB view details)

Uploaded Python 3

File details

Details for the file pycentroid-1.1.6.tar.gz.

File metadata

  • Download URL: pycentroid-1.1.6.tar.gz
  • Upload date:
  • Size: 59.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for pycentroid-1.1.6.tar.gz
Algorithm Hash digest
SHA256 d5b3394bc40a3ee2048d83fc6be2441a2a5f97a9482376d37fe57280013a5efd
MD5 55cf23dce6ee087200dbecf064464a18
BLAKE2b-256 bbaeda6769b550a9dafd6b8503bad162f583f8ae8c113e43b87b09c135dfd253

See more details on using hashes here.

File details

Details for the file pycentroid-1.1.6-py3-none-any.whl.

File metadata

  • Download URL: pycentroid-1.1.6-py3-none-any.whl
  • Upload date:
  • Size: 75.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.18

File hashes

Hashes for pycentroid-1.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 8d5fba9bf8b2f4a07e4de8ea5c34856a99efce967db81686570fe7e60956cbcb
MD5 6199707f2b6cbcc50e4b1a6e85730f23
BLAKE2b-256 db3898b19a7a9eb939db550900ea7079abc78d7456aed4f47b8b37dae407272d

See more details on using hashes here.

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