1

当我在 SearchQuerySet 上的 more_like_this 调用之前链接过滤器时,似乎根本没有应用过滤器。

from haystack.query import SearchQuerySet as sqs
from articles.models import Article

article = Article.objects.get(pk=4560) # Article instance of one of the many articles I have
sqs().filter(author='testest@testtest.com').count() # 147 - 147 documents with author=testest@testtest.com... so far so good
sqs().more_like_this(article).count() #54893
sqs().filter(author='testest@testtest.com').more_like_this(article).count() # 54893!!!

我假设这样做:

sqs().filter(author='testest@testtest.com').more_like_this(article)

会限制我在 147 个过滤文档中的 MLT 搜索,但这几乎就像过滤器被完全忽略一样。

我还尝试反转链的顺序:

sqs().more_like_this(article).filter(author='testest@testtest.com')

但最终返回整个搜索索引

有任何想法吗?提前致谢。

这是我的文章_text.txt

{{ object.title }}
{{ object.body.excerpt|striptags|escape }}

search_index.py

class ArticleIndexes(indexes.SearchIndex, indexes.Indexable):
    text = indexes.CharField(document=True, use_template=True, boost=1.1)
    author = indexes.CharField(model_attr='author')
    site_id = indexes.CharField(model_attr='site_id')
    # non-indexed, stored field
    stored_obj = ArticleStorageField(indexed=False)
4

1 回答 1

2

我很久以前就遇到过同样的问题——在 haystacks elasticsearch 后端没有实现类似这样的过滤。我已经向 pyelasticsearch 和 haystack 提出了拉取请求以使其正常工作。Pyelasticsearch 现在允许它,但 haystack 仍然没有支持(我已经关闭了我的拉取请求)。

此提交在干草堆中修复它: https ://github.com/jasisz/django-haystack/commit/76473d8eebf49a0fffba025993a533b852aa8578

于 2013-07-09T20:05:15.123 回答