Skip to main content

Django-filter is a reusable Django application for allowing users to filter querysets dynamically.

Project description

Django-filter is a reusable Django application for allowing users to filter querysets dynamically.

Full documentation on read the docs.

https://travis-ci.org/carltongibson/django-filter.svg?branch=master https://codecov.io/gh/carltongibson/django-filter/branch/develop/graph/badge.svg https://badge.fury.io/py/django-filter.svg

Requirements

  • Python: 2.7, 3.3, 3.4, 3.5

  • Django: 1.8, 1.9, 1.10, 1.11

  • DRF: 3.5

Installation

Install using pip:

pip install django-filter

Then add 'django_filters' to your INSTALLED_APPS.

INSTALLED_APPS = [
    ...
    'django_filters',
]

Usage

Django-filter can be used for generating interfaces similar to the Django admin’s list_filter interface. It has an API very similar to Django’s ModelForms. For example, if you had a Product model you could have a filterset for it with the code:

import django_filters

class ProductFilter(django_filters.FilterSet):
    class Meta:
        model = Product
        fields = ['name', 'price', 'manufacturer']

And then in your view you could do:

def product_list(request):
    filter = ProductFilter(request.GET, queryset=Product.objects.all())
    return render(request, 'my_app/template.html', {'filter': filter})

Django-filters additionally supports specifying FilterSet fields using a dictionary to specify filters with lookup types:

import django_filters

class ProductFilter(django_filters.FilterSet):
    class Meta:
        model = Product
        fields = {'name': ['exact', 'icontains'],
                  'price': ['exact', 'gte', 'lte'],
                 }

The filters will be available as 'name', 'name__icontains', 'price', 'price__gte', and 'price__lte' in the above example.

Support

If you have questions about usage or development you can join the mailing list.

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-filter-1.0.3.tar.gz (123.0 kB view details)

Uploaded Source

Built Distribution

django_filter-1.0.3-py2.py3-none-any.whl (43.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-filter-1.0.3.tar.gz.

File metadata

File hashes

Hashes for django-filter-1.0.3.tar.gz
Algorithm Hash digest
SHA256 6adeebc5853e8fd5211878895ab279f6be16b855e384957ffa574f669336ddc1
MD5 bcaed02f931cac9901db95a382ce7b34
BLAKE2b-256 7e5452429bb187338c41d9bce57831b65eb4cdd15503f682915f8f48061ae6fd

See more details on using hashes here.

File details

Details for the file django_filter-1.0.3-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_filter-1.0.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 0f2ad1f4a31aa66a8dc8e6cb8590c23848563e04b706c751bf69068a0d3cc57c
MD5 2ac8cfbebb5fc284fc07c05d9fddf64d
BLAKE2b-256 12c792cb4992dfbbd6773f4b4b947fc41baa3aa235adedb2f322143b0f7bf3b9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page