views:

39

answers:

1

Hi there,

I'm using django-taggit, which handles the attachment of tags to arbitrary content types. I imported a large tag list, which contains many uppercase words, as well as lowercase words.

Now, I' trying to get objects of another class containing a set of tags, but I want to compare case insensitively. When I do this:

Media.objects.filter(tags__name__in=['tag1', 'tag2'])

objects containing e.g. the tag "Tag1" are not found, only those ones with "tag1" or "tag2".

Is there any possibility in the django orm to do something like:

Media.objects.filter(tags__name__iin=['tag1', 'tag2'])

that acts like "icontains"?

+1  A: 

There is no easy way to do it. I'm not 100% sure, You can try something like this for your problem.

from django.models import Q

q = Q(1=1)
for tag in tags.split():
 q = q | Q(tags__name__iexact=tag)

Media.objects.filter(q)
iddqd
Since you are using iexact match, you do not neet to use <string>.lower() http://docs.djangoproject.com/en/1.2/ref/models/querysets/#iexact
FallenAngel
@FallenAngel bug resolved
iddqd
This works, thank you. However, I would appreciate an __iin-operator in the Django ORM.
schneck