gpt4 book ai didi

python - 在不需要 update_index 的情况下排除 Haystack 搜索中的对象

转载 作者:太空狗 更新时间:2023-10-30 01:02:32 44 4
gpt4 key购买 nike

我需要 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 在许多模型上工作的问题,因此过滤器会返回所有匹配项:

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/

44 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com