我如何在django-haystack搜索查询中使用布尔字段

Emo*_*gun 2 django django-haystack elasticsearch

我正在使用django-haystack来搜索我的应用程序,我有布尔字段我想过滤我的模型.但是,当我尝试这样做时,我的搜索查询失败.

我正在使用的搜索后端是elasticsearch

小智 5

在这里发布你的一些代码将有助于弄清楚你出了什么问题,因为很难解决你的问题.

我如何实现这个(使用whoosh而不是elasticsearch,但django代码应该是相同/相似的任何速率)是这样的:

创建了我自己的searchform类(如果你还没有这样做,请查看Haystack Docs - 创建自己的表单

from django import forms
from haystack.forms import SearchForm

class PaidPropertySearchForm(SearchForm):
    q = forms.CharField(required=False, label=('Town Area'))
    #othersearchtermshere
    furnished = forms.BooleanField(required=False)

    def search(self):
        sqs = super(PaidPropertySearchForm, self).search()
        #other search filtering here
        if self.is_valid() and self.cleaned_data['furnished']:
            sqs = sqs.filter(furnished__contains=self.cleaned_data['furnished'])

        return sqs
Run Code Online (Sandbox Code Playgroud)

相关的模型领域很简单:

class Properties (models.Model):.
    furnished = models.BooleanField()
Run Code Online (Sandbox Code Playgroud)

和我的searchindexes.py:

class PropertyIndex(indexes.SearchIndex, indexes.Indexable):
    #other indexed terms
    furnished = indexes.BooleanField(model_attr='furnished', default='false')
Run Code Online (Sandbox Code Playgroud)

这里值得注意的是,haystack和使用布尔值的whoosh后端之间存在一些问题,这要求我将defult索引值指定为字符串'false'而不是布尔值False.如果我没有这样做或没有设置默认值,由于某种原因,无论模型存储了什么,所有布尔值都被索引为True.我不知道这个问题是否会影响elasticsearch,所以你可能不需要

default='false'
Run Code Online (Sandbox Code Playgroud)

在您的搜索索引中

希望如果您还没有弄明白,这有助于您走上正确的轨道.