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)
在您的搜索索引中
希望如果您还没有弄明白,这有助于您走上正确的轨道.
| 归档时间: |
|
| 查看次数: |
1755 次 |
| 最近记录: |