Skip to main content

Allows users to filter Django models

Project description

Django Filtering

A library for filtering Django Models.

The original usecase for this project required the following:

  • provides a means of allowing users to filter modeled data
  • provides the ability to AND, OR and NOT filters (i.e. operators)
  • provides the ability to group filters by operator
  • serializes, validates, etc.

Installation

Install via pip or the preferred package manager:

pip install django-filtering

At this time, this package is more of a library than an installablable app. So there is no reason to add it to the Django project's INSTALLED_APPS.

Usage

The exposed portions of this package are a class named FilterSet and a factory function named filterset_factory. These are importable via:

from django_filterset.filters import filterset_factory, FilterSet

Say you have a Post model that you want user filters on. We'd start by creating a FilterSet through filterset_factory.

filters = {
    'title': ['icontains'],
    'author': [['fullname', 'iexact'], ['email', 'iexact']],
    'content': ['icontains'],
}
PostFilterSet = filterset_factory(Post, filters=filters)

Note, this package does not come with an interface for user filtering. One is under development, but not yet available for use. So we'll assume that some form posts or redirects the user to the following url:

/posts/?q=["and",[["title",{"lookup":"icontains","value":"foo"}],["content",{"lookup":"icontains","value":"bar"}]]

In this case we have a q query string value with JSON content, which we'll come back to in a bit.

Let's say this url is a listing view for Post objects, something that looks like:

def posts_list(request):
    filterset = PostFilterSet(json.dumps(request.GET.get('q')))
    objects = filterset.filter_queryset()
    return HttpResponse('\n'.join([o.get_absolute_url() for o in objects]))

You give the JSON serializable query data to the FilterSet and call the filter_queryset method to filter the results.

The JSON serialiable query data is a loosely lisp'ish data structure that looks something like:

query-data := [<operator>, [<filter|operator>,...]]
operator := 'and' | 'or' | 'not' | 'xor'
filter := [<field-name>, {"lookup": <lookup>, "value": <value>}]
field-name := string
lookup := string | array[string]
value := string

State of development

This package is very much a work-in-progress. All APIs are completely unstable.

Testing

Note, I'm testing within a docker container, because I never run anything locally. For the moment the container is simply run with:

docker run --rm --name django-filtering --workdir /code -v $PWD:/code -d python:3.12 sleep infinity

Then I execute commands on the shell within it:

docker exec -it django-filtering bash

License

GPL v3 (see LICENSE file)

Copyright

© 2024 The Shadowserver Foundation

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

django_filtering-0.0.4.tar.gz (22.7 kB view details)

Uploaded Source

Built Distribution

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

django_filtering-0.0.4-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file django_filtering-0.0.4.tar.gz.

File metadata

  • Download URL: django_filtering-0.0.4.tar.gz
  • Upload date:
  • Size: 22.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for django_filtering-0.0.4.tar.gz
Algorithm Hash digest
SHA256 29262dc1be3a288dda4fe53d41a21c636b406a3917c08265aa82f256aaab27a8
MD5 d4ecffbc6651106ad232a042df061079
BLAKE2b-256 e72cd8a48f75b8e5bc0dd4d89faced2ac0fe27f69bed09fe155a2b129031796e

See more details on using hashes here.

File details

Details for the file django_filtering-0.0.4-py3-none-any.whl.

File metadata

File hashes

Hashes for django_filtering-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 213019d6d9c74db802a303e8c523300085523ef1bef460726c21c9dd20fb4eea
MD5 8f0b18abf61d1cc71a1588beb2296f75
BLAKE2b-256 440b31605f0728cb9039d48bb2a272b289590ecfeb3d96080c2d7f73f2d1e206

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