Skip to main content

Provides a relational query language that is pythonic and intuitive. Entity Query Language serves as a front end to other query languages like sql or prolog

Project description

Entity Query Language (EQL)

EQL is a relational query language that is pythonic, and intuitive.

The interface side of EQL is inspired by euROBIN entity query language white paper.

Installation

pip install entity_query_language

Documentation

Read the documentation here.

Example Usage

An important feature of EQL is that you do not need to do operations like JOIN in SQL, this is performed implicitly. EQL tries to mirror your intent in a query statement with as less boiler plate code as possiple. For example an attribute access with an equality check to another value is as simple as using python's dot notation with the equality operator. For example:

from dataclasses import dataclass

from typing_extensions import List

from entity_query_language import entity, an, let, contains, symbolic_mode, symbol


@symbol
@dataclass
class Body:
    name: str


@dataclass
class World:
    id_: int
    bodies: List[Body]


world = World(1, [Body("Body1"), Body("Body2")])

with symbolic_mode():
    body = let(type_=Body, domain=world.bodies)
    query = an(entity(body, contains(body.name, "2"),
                      body.name.startswith("Body"))
               )
results = list(query.evaluate())
assert len(results) == 1
assert results[0].name == "Body2"

where this creates a body variable that gets its values from world.bodies, and filters them to have their att "name" equal to "Body1".

To Cite:

@software{bassiouny2025eql,
author = {Bassiouny, Abdelrhman},
title = {Entity-Query-Language},
url = {https://github.com/AbdelrhmanBassiouny/entity_query_language},
version = {2.0.0}
}

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

entity_query_language-2.0.1.tar.gz (93.7 kB view details)

Uploaded Source

Built Distribution

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

entity_query_language-2.0.1-py3-none-any.whl (60.7 kB view details)

Uploaded Python 3

File details

Details for the file entity_query_language-2.0.1.tar.gz.

File metadata

  • Download URL: entity_query_language-2.0.1.tar.gz
  • Upload date:
  • Size: 93.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for entity_query_language-2.0.1.tar.gz
Algorithm Hash digest
SHA256 05042af0fe9bcc6bc5d6bf4e67da05cbc993f5311ff37b00310620adf76b4aec
MD5 04a0548870f35053ccc2d2917bbf47cc
BLAKE2b-256 8bf18cd5e2e902244b0abf6a731a29c2f02cc358bb50d8d4d1913b113f2cb9ad

See more details on using hashes here.

Provenance

The following attestation bundles were made for entity_query_language-2.0.1.tar.gz:

Publisher: publish-to-test-pypi.yml on AbdelrhmanBassiouny/entity_query_language

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

File details

Details for the file entity_query_language-2.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for entity_query_language-2.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8302e7799a51db63fedb9b90ab073eef9c2a874e06ee8537a5f0311b049bd0f0
MD5 e33c36e416991b222611a6a13c99de67
BLAKE2b-256 4494028fa96f9df5c4ded17a9ae2ac5add44b34130a7d45c394c3e780204e6aa

See more details on using hashes here.

Provenance

The following attestation bundles were made for entity_query_language-2.0.1-py3-none-any.whl:

Publisher: publish-to-test-pypi.yml on AbdelrhmanBassiouny/entity_query_language

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