我正在寻找使用 ModelForm 类构建一个搜索表单,它允许用户通过特定字段而不是单个字段关键字搜索来搜索模型中的值。我还希望忽略空字段。
我研究了诸如 Haystack 和 Djapian 之类的搜索引擎选项,以及在 Django 中手动解决问题,但是在使用多个字段进行查询时,我似乎无法获得结果。
这是我迄今为止的观点,部分基于对本网站上一些类似问题的回答,以及记录的内容:
def search(request):
error = False
form = InfoForm()
if 'field1' or 'field2' or 'field3' in request.GET:
form = InfoForm(request.GET)
if form.is_valid():
cd = form.cleaned_data
field1 = cd['field1']
field2 = cd['field2']
field3 = cd['field3']
if not(field1 or field2 or field3):
error = True
else:
query = Q()
if request.GET['field1']:
query &= Q(field1__icontains=request.GET['field1'])
if request.GET['field2']:
query &= Q(field2__icontains=request.GET['field2'])
if request.GET['field3']:
query &= Q(field3__icontains=request.GET['field3'])
results = PersonInfo.objects.filter(query).distinct()
return render_to_response('search/personsearch.html',
{'query': query,
'field1': field1,
'field2': field2,
'field3': field3,
'results': results,
},
context_instance=RequestContext(request))
return render_to_response('search/infosearch.html',
{'error': error,
'form': form},
context_instance=RequestContext(request))
我还直接从文档中尝试了这个复杂的查询:
query = InfoModel.objects.get(
Q(field1__icontains=field1) |
Q(field2__icontains=field2) |
Q(field3__icontains=field3)
)
在这两种情况下,查询字符串都?field1=&field2=&field3=
出现在 URL 的后面,并且页面返回字段中提供的字段值,如预期的那样;但如果所有字段都留空,则不会返回结果或生成错误。
我显然错过了一些东西,但对于我的生活,我无法弄清楚是什么。有没有其他人遇到过这个问题?