Generating all possible subsets of a given QuerySet in Django

Posted by Glen on Stack Overflow See other posts from Stack Overflow or by Glen
Published on 2010-04-11T20:44:54Z Indexed on 2010/04/11 20:53 UTC
Read the original article Hit count: 193

Filed under:
|
|

This is just an example, but given the following model:

class Foo(models.model):
    bar = models.IntegerField()

    def __str__(self):
        return  str(self.bar)

    def __unicode__(self):
        return str(self.bar)

And the following QuerySet object:

foobar = Foo.objects.filter(bar__lt=20).distinct()

(meaning, a set of unique Foo models with bar <= 20), how can I generate all possible subsets of foobar? Ideally, I'd like to further limit the subsets so that, for each subset x of foobar, the sum of all f.bar in x (where f is a model of type Foo) is between some maximum and minimum value.

So, for example, given the following instance of foobar:

>> print foobar
[<Foo: 5>, <Foo: 10>, <Foo: 15>]

And min=5, max=25, I'd like to build an object (preferably a QuerySet, but possibly a list) that looks like this:

[[<Foo: 5>], [<Foo: 10>], [<Foo: 15>], [<Foo: 5>, <Foo: 10>],
 [<Foo: 5>, <Foo: 15>], [<Foo: 10>, <Foo: 15>]]

I've experimented with itertools but it doesn't seem particularly well-suited to my needs.

I think this could be accomplished with a complex QuerySet but I'm not sure how to start.

© Stack Overflow or respective owner

Related posts about python

Related posts about django