RQL (Resource query language) is designed for modern application development. It is built for the web, ready for NoSQL, and highly extensible with simple syntax. This is a query language fast and convenient database interaction. RQL was designed for use in URLs to request object-style data structures.
Python RQL can be installed from pypi.org using pip:
$ pip install lib-rql
Python RQL documentation is hosted on the Read the Docs service.
Django RQL is the Django app, that adds RQL filtering to your application.
Visit the Django RQL project repository for more informations.
Parsing is done with Lark (cheatsheet). The current parsing algorithm is LALR(1) with standard lexer.
- Values with whitespaces or special characters, like ',' need to have "" or ''
- Supported date format is ISO8601: 2019-02-12
- Supported datetime format is ISO8601: 2019-02-12T10:02:00 / 2019-02-12T10:02Z / 2019-02-12T10:02:00+03:00
- Comparison (eq, ne, gt, ge, lt, le, like, ilike, search)
- List (in, out)
- Logical (and, or, not)
- Constants (null(), empty())
- Ordering (ordering)
- Select (select)
- Tuple (t)
from py_rql import parse
from py_rql.exceptions import RQLFilterError
try:
    tree = parse('eq(key,value)')
except RQLFilterError:
    passfrom py_rql.constants import FilterTypes
from py_rql.filter_cls import FilterClass
class BookFilter(FilterClass):
    FILTERS = [
        {
            'filter': 'title',
        },
        {
            'filter': 'author.name',
        },
        {
            'filter': 'status',
        },
        {
            'filter': 'pages',
            'type': FilterTypes.INT,
        },
        {
            'filter': 'featured',
            'type': FilterTypes.BOOLEAN,
        },
        {
            'filter': 'publish_date',
            'type': FilterTypes.DATETIME,
        },
    ]
filters = BookFilter()
query = 'eq(title,Practical Modern JavaScript)'
results = list(filters.filter(query, DATA))
print(results)
query = 'or(eq(pages,472),lt(pages,400))'
results = list(filters.filter(query, DATA))
print(results)- Python 3.8+
- Install dependencies pip install poetry && poetry install
- Python 3.8+
- Install dependencies pip install poetry && poetry install
Check code style: poetry run flake8
Run tests: poetry run pytest
Tests reports are generated in tests/reports.
- out.xml- JUnit test results
- coverage.xml- Coverage xml results
To generate HTML coverage reports use:
--cov-report html:tests/reports/cov_html
Python RQL is released under the Apache License Version 2.0.