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

  • DRF: 3.5

Installation

Install using pip:

pip install django-filter

Or clone the repo and add to your PYTHONPATH:

git clone git@github.com:carltongibson/django-filter.git

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.2.tar.gz (120.3 kB view details)

Uploaded Source

Built Distribution

django_filter-1.0.2-py2.py3-none-any.whl (42.7 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

File hashes

Hashes for django-filter-1.0.2.tar.gz
Algorithm Hash digest
SHA256 11cc64a75c708ca72d03b8bafa2ee2908debc41ae942a55b01fdaed375b5ee14
MD5 5b584ecdc7e2489ce11bca213f30a855
BLAKE2b-256 335d86a3d783f337cadc9ad52d43817b63a9d2f088cf85aec62b1ef766b943f2

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for django_filter-1.0.2-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a6a1b59fc7c9c5da17af1c5c98490f89d2df26b9501934a54d814414af9ee1ac
MD5 83aa07f67ac700cba01206f0ae84f201
BLAKE2b-256 a84969541b01452471fa4b101beae58af60977fa5cfd6c297a18fd1ee03674bf

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