I have a list qObjects = [qObject1, qObject2, qObject3]
What I'd like is to form this query: Sample.objects.filter(qObject1,
qObject2, qObject3)
How would I accomplish what I need? Thanks!
Have you tried the filter you wrote above?
Try this:
Sample.objects.filter(*qObjects)
______________________
Vinícius Mendes
Solucione Sistemas
http://solucione.info/
Sample.objects.filter(*qObjects)
--
You received this message because you are subscribed to the Google Groups "Django users" group.
To post to this group, send email to django...@googlegroups.com.
To unsubscribe from this group, send email to django-users...@googlegroups.com.
For more options, visit this group at http://groups.google.com/group/django-users?hl=en.
Thank you for your help everyone. I know that I need to learn python
better, and I did read those articles. What is still a bit unclear to
me, though, is how could I add an "OR" or "AND" separator between Q
objects?
So I have a list of qobjects like [qObj1, qObj2, qObj3].
What I want is something like Sample.objects.filter((qObj1 | qObj2),
qObj3)
I know that the default is for all Q objects to be "ANDed" together.
I think the join operation is not going to work here, nor is
concatenation, but is there something obvious that I'm missing?
THANK YOU :>
On Apr 6, 7:14 am, Vinicius Mendes <vbmen...@gmail.com> wrote:
> I recommend you to read more documentation about python. It's a basic python
> feature. You can read more about it here:
>
> http://www.saltycrane.com/blog/2008/01/how-to-use-args-and-kwargs-in-...
>
> Try this:
>
> Sample.objects.filter(*qObjects)
>
> ______________________
> Vinícius Mendes
> Solucione Sistemashttp://solucione.info/
>
> On Tue, Apr 6, 2010 at 2:54 AM, Aaron <byco...@gmail.com> wrote:
> > Sample.objects.filter(*qObjects)
>
> > On Apr 6, 1:10 am, Daniel <unagimiy...@gmail.com> wrote:
> > > Hi, I think that this must be super easy, but I'm kind of stumped.
>
> > > I have a list qObjects = [qObject1, qObject2, qObject3]
> > > What I'd like is to form this query: Sample.objects.filter(qObject1,
> > > qObject2, qObject3)
>
> > > How would I accomplish what I need? Thanks!
>
> > --
> > You received this message because you are subscribed to the Google Groups
> > "Django users" group.
> > To post to this group, send email to django...@googlegroups.com.
> > To unsubscribe from this group, send email to
> > django-users...@googlegroups.com<django-users%2Bunsu...@googlegroups.com>
Documentation on how to combine Q objects:
http://docs.djangoproject.com/en/1.1/topics/db/queries/#complex-lookups-with-q-objects
So you want to loop through them, and 'or' them together..
filters = [ q1, q2, q3, q4, q5 ]
q = None
for f in filters:
q = q | f if q else f
Foo.objects.filter(q)
Tom
Tom
--
You received this message because you are subscribed to the Google Groups "Django users" group.
To post to this group, send email to django...@googlegroups.com.
To unsubscribe from this group, send email to django-users...@googlegroups.com.
q = q | f if q else f
That line of code only allows (q1 | q2 | q3), right?
It will not allow mixing "AND" as well as "OR" (i.e., q1 & q2 | q3)?
Thanks!
On Apr 7, 1:26 pm, Vinicius Mendes <vbmen...@gmail.com> wrote:
> On Wed, Apr 7, 2010 at 2:00 PM, Tom Evans <tevans...@googlemail.com> wrote:
> > On Wed, Apr 7, 2010 at 5:39 PM, Daniel <unagimiy...@gmail.com> wrote:
> > > Hi,
>
> > > Thank you for your help everyone. I know that I need to learn python
> > > better, and I did read those articles. What is still a bit unclear to
> > > me, though, is how could I add an "OR" or "AND" separator between Q
> > > objects?
>
> > > So I have a list of qobjects like [qObj1, qObj2, qObj3].
>
> > > What I want is something like Sample.objects.filter((qObj1 | qObj2),
> > > qObj3)
>
> > > I know that the default is for all Q objects to be "ANDed" together.
> > > I think the join operation is not going to work here, nor is
> > > concatenation, but is there something obvious that I'm missing?
>
> > > THANK YOU :>
>
> > Documentation on how to combine Q objects:
>
> >http://docs.djangoproject.com/en/1.1/topics/db/queries/#complex-looku...
>
> > So you want to loop through them, and 'or' them together..
>
> > filters = [ q1, q2, q3, q4, q5 ]
> > q = None
> > for f in filters:
> > q = q | f if q else f
> > Foo.objects.filter(q)
>
> Refining a little:
>
> filters = [q1,q2,q3,q4,q5]
> q = Q()
> for f in filters:
> q |= f
> Foo.objects.filter(q)
>
> Q() is identity for & and |.
>
> > Tom
>
> > --
> > You received this message because you are subscribed to the Google Groups
> > "Django users" group.
> > To post to this group, send email to django...@googlegroups.com.
> > To unsubscribe from this group, send email to
> > django-users...@googlegroups.com<django-users%2Bunsu...@googlegroups.com>
To unsubscribe from this group, send email to django-users...@googlegroups.com.
You could go one further and use
filters = [q1,q2,q3,q4,q5]
q = reduce(lambda x,y: x|y, filters, Q())
Foo.objects.filter(q)
--
G
q = q | f if q else f
is using the short version of if/else, so let's expand that:
if q:
q = q | f
else:
q = f
q is only False when you have a Q object with no parameters i.e. Q()
and as you may have seen above | means OR. This is because the Q
object implements the __or__ special method.
To unsubscribe from this group, send email to django-users...@googlegroups.com.
Just to clarify:
python:
a = c if b else d
java:
a = b ? c : d;
see http://docs.djangoproject.com/en/dev/topics/db/queries/#complex-lookups-with-q-objects