首页 > 解决方案 > 小写字段值 django 模型查询集

问题描述

我有一个对象的模型,并且为该模型的对象分配了几个标签。标签可以是大写、小写或两种情况的混合。我想编写一个查询集,它将返回那些具有我提供的相同标签的对象。注意:我正在使用 django-taggit 模块。
视图.py

def home(request):
    book = Book.objects.filter(tags__name__in= map(lambda s:s.lower(), ['harry-potter', 'Champak', 'Physics']))
    print(book)
    return HttpResponse("Books Retrieved")

模型.py

from django.db import models
from django.utils.translation import ugettext_lazy as _

from taggit.managers import TaggableManager
from taggit.models import GenericUUIDTaggedItemBase, TaggedItemBase

class UUIDTaggedItem(GenericUUIDTaggedItemBase, TaggedItemBase):
    class Meta:
        verbose_name = _("Tag")
        verbose_name_plural = _("Tags")

class Book(models.Model):
    name = models.CharField(max_length=100)
    details = models.TextField(blank=True)
    tags = TaggableManager(through=UUIDTaggedItem, blank = True)

现在我想退回所有标签为“哈利波特”、“哈利波特”或任何其他词的书。

PS:如果我们可以降低'tags__name__in'列表,我们的工作就完成了。

标签: pythondjangodjango-modelsdjango-rest-frameworkdjango-taggit

解决方案


您可以使用以下方法制作一个Q过滤大小写敏感对象:

from django.db.models import Q

data = ['harry-potter', 'Champak', 'Physics']

qfilter = Q(
    *[Q(tags__name__iexact=item) for item in data],
    _connector=Q.OR
)

Book.objects.filter(
    qfilter
)

[ __iexactDjango-doc]将不区分大小写地与每个itemin匹配data


推荐阅读