好吧,我现在已经把头发拉了过来好几个小时了,并认为是时候寻求帮助,因为我无法通过谷歌搜索找出原因:...
基本上我正在制作一个分类型应用程序,我需要一个搜索表单来搜索数据库并根据各种标准进行过滤。我正在使用django,haystack和whoosh,我几乎可以完美地工作,但我似乎无法对布尔变量进行过滤。我已经成功地在Charfield类别上进行了过滤,并且它完美地工作但是当我尝试基于for_sale布尔值(或任何布尔值)添加过滤器时,它不会过滤任何内容并返回相同的结果,就好像它从未被调用过(我已经检查过并且它实际上被调用了)。
有人有什么想法吗?
我的模型的相关部分:
class Listing(models.Model):
SALE_CHOICES=((True, 'Items for sale'),
(False, 'Items wanted'))
for_sale = models.BooleanField(choices=SALE_CHOICES, default=True)
CAT_CHOICES = ((WOOD, "Woods"), (BRICKS, "Bricks"), etc)
category = models.CharField(max_length=6, choices = CAT_CHOICES, default = WOOD)
这是我的列表索引类:
class ListingIndex(indexes.SearchIndex, indexes.Indexable):
text = indexes.CharField(document=True, use_template=True)
title = indexes.CharField(model_attr='title')
text_content = indexes.CharField(model_attr='text_content')
created = indexes.DateTimeField(model_attr='created')
url = indexes.CharField(model_attr='url')
price = indexes.CharField(model_attr='price', null=True)
city = indexes.CharField(model_attr='city', null=True)
category = indexes.CharField(model_attr='category')
for_sale = indexes.BooleanField(model_attr='for_sale', default=True)
def get_model(self):
return Listing
def index_queryset(self, using=None):
return self.get_model().objects.filter(expired=False).filter(verified=True)
我的扩展SearchForm和SearchView:
class ListingSearchForm(FacetedSearchForm):
cat = forms.CharField(required=False, widget=forms.Select(choices=get_listings_categories()))
type = forms.CharField(required=False, widget=forms.HiddenInput)
for_sale = forms.BooleanField(required=False, widget=forms.Select(choices=get_sale_categories()))
def search(self):
# First, store the SearchQuerySet received from other processing.
sqs = super(ListingSearchForm, self).search()
# Check to see if a category was chosen.
if self.cleaned_data['cat']:
sqs = sqs.filter(category=self.cleaned_data['cat'])
# Check to see if a type was chosen.
if self.cleaned_data['for_sale']:
sqs = sqs.filter(for_sale=self.cleaned_data['for_sale'])
return sqs
class ListingSearchView(SearchView):
def extra_context(self):
extra = super(ListingSearchView, self).extra_context()
extra['post_type'] = self.request.GET.get('type', None)
extra['cat'] = self.request.GET.get('cat', None)
extra['for_sale'] = self.request.GET.get('for_sale', None)
return extra
最后我的列表索引文本文件:
{{ object.title }}
{{ object.text_content }}
{{ object.created }}
{{ object.url }}
{{ object.category }}
{{ object.price }}
{{ object.city }}
{{ object.for_sale }}
答案 0 :(得分:1)
我最终将我的for_sale字段重新设置为CharField,现在我可以很好地过滤它了。
Haystack或Whoosh只是不喜欢布尔,我猜哈哈。
答案 1 :(得分:0)
它可能与issue #371 in Haystack相同:
我注意到,当Python值为True和False时,whoosh存储布尔值,而haystack则将字符串'true'和'false'存储起来,如果查询,则将其评估为True。
另外查询我的索引需要使用字符串't'和'f'作为布尔字段。使用此补丁,可以使用True或False进行查询。
这显然是fixed in Whoosh,在2.4x分支中(在2.41发布之后,因此尚未提供)和2.5.0及更高版本。