django queryset - 搜索名字和姓氏

Luk*_*uke 6 django django-models django-forms django-views

我有一个django应用程序,从一个用户表中检索所有主题.我还实现了一个输入搜索表单,这是执行的查询:

all_soggs =     Entity.objects.filter(lastname__istartswith=request.GET['query_term']).order_by('lastname')
if(all_soggs.count()==0):
    all_soggs = Entity.objects.filter(firstname__istartswith=request.GET['query_term']).order_by('firstname')
Run Code Online (Sandbox Code Playgroud)

正如您所见,查询首先按姓氏搜索匹配的项目,然后按名字搜索.这是有效的,直到我插入完整的名称'firstaname lastname'或'lastname firstname',在这种情况下,没有结果.如何修改查询以进行更好的搜索?

谢谢 - 卢克

laf*_*ste 9

复制/粘贴自:https://stackoverflow.com/a/17361729/1297812

from django.db.models import Q 

def find_user_by_name(query_name):
   qs = User.objects.all()
   for term in query_name.split():
     qs = qs.filter( Q(first_name__icontains = term) | Q(last_name__icontains = term))
   return qs
Run Code Online (Sandbox Code Playgroud)


Yuj*_*ita 7

您需要Q对象,并且还需要将查询拆分为单独的术语(因为没有名字将与完整字符串"Firstname Lastname"匹配).

这是一个匹配搜索"名字姓氏"中以"名字"或"姓氏"开头的任何名字或姓氏的想法.

这是一般搜索 - 调整查询以满足您的特定需求!

编辑:oops,我真的不喜欢使用reduce,因为它看起来很混乱,但是这些需要ORed在一起,我们不能做一个更详细的版本,因为术语的数量是未知的.

import operator
from django.db.models import Q

search_args = []
for term in request.GET['query_term'].split():
    for query in ('first_name__istartswith', 'last_name__istartswith'):
        search_args.append(Q(**{query: term}))

all_soggs = Entity.objects.filter(reduce(operator.or_, search_args))
Run Code Online (Sandbox Code Playgroud)

为了阐明如何使用Q对象,给定搜索"Firstname Lastname",前一个查询等于:

Entity.objects.filter(
    Q(first_name__istartswith="Firstname") | Q(last_name__istartswith="Firstname") |
    Q(first_name__istartswith="Lastname") | Q(last_name__istartswith="Lastname")
    )
Run Code Online (Sandbox Code Playgroud)