我需要Haystack搜索来排除某些值为published=False
的对象,到目前为止,我对其进行管理的方式是通过添加exclude(published=True)
如下:
class MymodelIndex(indexes.RealTimeSearchIndex, indexes.Indexable):
def get_queryset(self):
return Mymodel.objects.all().exclude(published=False)
它按预期工作,问题是每次将新对象添加到数据库中时,我都需要
./manage.py rebuild_index
,这很糟糕。我如何可以在不运行其他任何东西的情况下做到这一点?
笔记:
Haystack上的索引适用于许多模型,因此如下所示:
search = (
SearchQuerySet().filter(content=term)
)
返回许多对象,而不仅仅是一个模型。
谢谢
最佳答案
我最近不得不做类似的事情,这真是太痛苦了。我找不到其他方法可以做到这一点。
首先是要解决Haystack在许多模型上的问题,因此filter返回所有匹配项:
Haystack使用其索引的属性django_ct处理幕后的模型过滤,该属性等于应用程序名称和模型名称。在我的特殊情况下,它看起来像django_ct='books.Title'
。
您可以尝试通过执行过滤
SearchQuerySet.filter(content=term, django_ct='app.Model')
但是我不知道它是否可以那样工作。在我的特殊情况下,无论如何我都必须进行原始搜索,因此我可以直接向其中添加过滤条件:
sqs = SearchQuerySet()
sqs = sqs.raw_search(u'(title:(%s)^500 OR author:"%s"^400 OR "%s"~2 OR (%s)) AND (django_ct:books.Title)' % term)
无论如何获取,在获取
SearchQuerySet
后,您都希望对它们进行其他过滤而不更新索引,则必须使用自己的代码来进行处理。# each item in a queryset has a pk property to the model instance it references
pks = [item.pk for item in list(sqs)] # have to wrap sqs in a list otherwise it causes problems
# use those pks to create a standard django queryset object
results = Model.objects.filter(pk__in=pks)
# Now you can do any additional filtering like normal
results = results.exclude(published=False)
当然,您可以结合使用最后两个查询,我只是将它们拆分为明确的。
它不是很多代码,但是由于各种原因,我花了很长时间才使它开始工作。希望它可以帮助您。
关于python - 无需update_index即可在Haystack搜索中排除对象,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/15373305/