Skip to main content

A predicate class constructed like Django Q objects, used to test whether a new or modified model would match a query

Project description

django-predicate provides a Q like object to facilitate the question: “would this model instance be part of a query” but without running the query or even saving the object.

Quickstart

Install django-predicate:

pip install django-predicate

Then use the P object just as you would Q objects:

from predicate import P

p = P(some_field__startswith="hello", age__gt=20)

You can then call the eval method with a model instance to check whether it passes the conditions:

model_instance = MyModel(some_field="hello there", age=21)
other_model_instance = MyModel(some_field="hello there", age=10)
p.eval(model_instance)
>>> True
p.eval(other_model_instance)
>>> False

or you can use Python’s in operator.

model_instance in p
>>> True

Even though a predicate is not a true container class - it can be used as (and was designed as being) a virtual “set” of objects that meets some condiiton.

Like Q objects, P objects can be &’ed and |’ed together to form more complex logic groupings.

In fact, P objects are actually a subclass of Q objects, so you can use them in queryset filter statements:

qs = MyModel.objects.filter(p)

If you have a situation where you want to use querysets and predicates based on the same conditions, it is far better to start with the predicate. Because of the way querysets assume a SQL context, it is non-trivial to reverse engineer them back into a predicate. However as seen above, it is very straightforward to create a queryset based on a predicate.

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-predicate-0.1.1.tar.gz (12.3 kB view details)

Uploaded Source

File details

Details for the file django-predicate-0.1.1.tar.gz.

File metadata

File hashes

Hashes for django-predicate-0.1.1.tar.gz
Algorithm Hash digest
SHA256 d6c262b894455a49f5ed8a067c0af1d4b3dfa9f365532ded53240bf0ee6f9429
MD5 a27061cd3d739b8496f7777f19a336b9
BLAKE2b-256 b5401fe2e438772560a8ce3f4cf69826781155911b7741a2ca04cc426f44e5eb

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