Haystack, SearchQuerySet(). Фильтр ничего не возвращает. (Django + эластичный поиск)

Мой код выглядит следующим образом. здесь SearchQuerySet().filer ничего не возвращает.

search_indexes.py

class sample_index(indexes.SearchIndex, indexes.Indexable):
    text = indexes.CharField(document=True, use_template=True)
    books = indexes.CharField(model_attr='books')
    search_tags = indexes.MultiValueField()

    def prepere_tags(self, obj):
        return [tag.tag for tag in obj.seacrh_tags.all()]

    def get_model(self):
        return sample

    def index_queryset(self, using=None):
        return self.get_model().objects

    def load_all_queryset(self):
        return sample.objects.all().select_related()
model.py
class tags(models.Model):    
    tag = models.CharField(max_length=4, unique=True, db_index=True)

    def __unicode__(self):
        return unicode(self.tag)

class sample(models.Model):

books = models.CharField(db_index=True, max_length=256, null=False)
search_tags = models.ManyToManyField(tags, db_index=True)

def __unicode__(self):
    return unicode(self.md5sum)

view.py

def search_h(request):

    search_string = request.GET.get('search_string', '')
    values = []

    sqs = SearchQuerySet().filter(search_tags=search_string)

    values = [a.object for a in sqs[0:10]]

    return render(request, "search/indexes/app/test.html", {'values': values})

sample_text.txt

{{ object.text }}
{% for tag in object.search_tags.all %}
{{ tag.tag }}
{% endfor %}

Здесь значения - пустой список. даже квадраты приходят как пустые. Любая идея, что мне здесь не хватает.

1 ответ

Вы определили следующее поле в индексе search_tags = indexes.MultiValueField(), Но вы готовите MultiValueField tags (prepare_tags) которого нет в индексе, оно должно быть prepare_search_tags:

def prepare_search_tags(self, obj): return [tag.tag for tag in obj.seacrh_tags.all()]

Другие вопросы по тегам