Skip to main content

DjangoQL: Advanced search language for Django (iplweb fork with i18n)

Project description

DjangoQL

Tests PyPI Python Version Django Version License

Advanced search language for Django, with auto-completion. Supports logical operators, parenthesis, table joins, and works with any Django model. Tested on Python 3.10–3.14, Django 5.2 and 6.0. The auto-completion feature has been tested in Chrome, Firefox, Safari, IE9+.

This is a community fork. djangoql-iplweb is a fork of the original DjangoQL by ivelum — install the upstream package from djangoql on PyPI. This fork adds internationalization (i18n) of error messages and modernized packaging/tooling.

These changes are offered back to the upstream project. If the original maintainers merge them, please switch back to the upstream djangoql package — this fork exists only to make the improvements available in the meantime, and will defer to upstream once they land there.

It is published on PyPI as djangoql-iplweb, but the import name stays djangoql (so INSTALLED_APPS and import djangoql are unchanged).

See a video: DjangoQL demo

DjangoQL auto-completion example

Features

  • Python-like query syntax: logical operators (and, or), parenthesis, and the full set of comparison operators
  • Searches across model relations via joins, e.g. author.last_name = "Tolstoy"
  • Works with any Django model and drops into the Django admin with a single mixin
  • Live auto-completion of model field names and values in the admin
  • Configurable schema to restrict searchable models/fields and provide suggestion options
  • Custom search fields for annotations and fully custom search logic
  • Internationalized error messages with translation catalogs for 11 locales
  • Usable outside the Django admin, including a standalone JavaScript completion widget
  • Multi-line queriesShift+Enter inserts a newline (Enter still submits)
  • Pretty-print / formatting — re-indent a query via format_query() or the …/format/ endpoint
  • Per-branch record counts — see how many rows each sub-expression matches via explain() or the …/explain/ endpoint
  • Syntax highlighting — a tokenizer (DjangoQLHighlight.tokenize) plus a lightweight, restyleable overlay; no palette or editor imposed

Installation

Using uv (recommended):

$ uv add djangoql-iplweb

Using pip:

$ pip install djangoql-iplweb

Add 'djangoql' to INSTALLED_APPS in your settings.py:

INSTALLED_APPS = [
    ...
    'djangoql',
    ...
]

For full setup instructions and usage examples, see the Documentation below.

Documentation

📖 Full documentation: https://iplweb.github.io/djangoql-iplweb/

The site is built with MkDocs from the docs/ directory. Key pages:

Example project

A runnable demo of all the features above (on a richly related dataset) lives in example_project/. See its README for details. Quick start:

cd example_project
uv run python manage.py migrate
uv run python manage.py seed_demo          # lots of related demo data
uv run python manage.py createsuperuser    # optional, for the admin
uv run python manage.py runserver

Then open http://127.0.0.1:8000/ (search demo — auto-completion, multi-line, highlighting, Format, Explain counts) or http://127.0.0.1:8000/admin/ (admin with completion + multi-line + the highlight overlay).

What it looks like

Running a query — live syntax highlighting and results:

Search demo

The Format button re-indents a query (syntax highlighting throughout):

Formatted query

Explain counts breaks an empty result down per sub-expression, so you can see where the data runs out — here each side matches ~500 rows but their and matches none:

Per-branch counts for an empty result

Syntax errors are pinpointed in the query box:

Syntax error highlighted

Supported by

This fork is graciously supported and maintained by iplweb.

iplweb

License

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

djangoql_iplweb-0.27.1.tar.gz (304.2 kB view details)

Uploaded Source

Built Distribution

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

djangoql_iplweb-0.27.1-py3-none-any.whl (362.9 kB view details)

Uploaded Python 3

File details

Details for the file djangoql_iplweb-0.27.1.tar.gz.

File metadata

  • Download URL: djangoql_iplweb-0.27.1.tar.gz
  • Upload date:
  • Size: 304.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for djangoql_iplweb-0.27.1.tar.gz
Algorithm Hash digest
SHA256 616b13b3e9d6ed3a38b9bfb9fdd7e62f9f40e6e034188c73bb72c59aedddc858
MD5 3e04104df91cc0f5c2ae4dad0cfbd325
BLAKE2b-256 abc0a58234bda80e8b0924a77ee105d290a3ed76a7865b29b4c618e175a75fbf

See more details on using hashes here.

File details

Details for the file djangoql_iplweb-0.27.1-py3-none-any.whl.

File metadata

  • Download URL: djangoql_iplweb-0.27.1-py3-none-any.whl
  • Upload date:
  • Size: 362.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.11.14 {"installer":{"name":"uv","version":"0.11.14","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for djangoql_iplweb-0.27.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7665576d1656b79dc9e798102557bac7069cba50f6f6793eb80f71e3a8a9ce3d
MD5 56ddfd9114a37c75658ea3ad7c3943ac
BLAKE2b-256 fe17b5a37d01dde8c7f6e799a247f59e7d6575d8e28faf6128a123f3f8332ba5

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