Django -Haystack и Elasticsearch тормозят запросы, содержащие специальные символы - PullRequest
0 голосов
/ 10 июля 2020

Итак, я пытался исправить ошибку, которая меня действительно раздражает: Django - Запросы Haystack и Elasticsearch работают с акцентами, но каждый раз тормозит запросами, содержащими специальные символы, такие как da sh - и апострофы '.

Например, давайте использовать Baie-d'Urfé в качестве запроса.

Вот мой код:

forms.py

class FacetedProductSearchForm(FacetedSearchForm):

def __init__(self, *args, **kwargs):
    data = dict(kwargs.get("data", []))
    self.ptag = data.get('ptags', [])
    self.q_from_data = data.get('q', '')
    super(FacetedProductSearchForm, self).__init__(*args, **kwargs)

def search(self):
    sqs = super(FacetedProductSearchForm, self).search()

    # Ideally we would tell django-haystack to only apply q to destination
    # ...but we're not sure how to do that, so we'll just re-apply it ourselves here.
    q = self.q_from_data
    sqs = sqs.filter(destination=Exact(q))

    print('should be applying q: {}'.format(q))
    print(sqs)

    if self.ptag:
        print('filtering with tags')
        print(self.ptag)
        sqs = sqs.filter(ptags__in=[Exact(tag) for tag in self.ptag])

    return sqs

Использование FacetedSearch в View.py

class FacetedSearchView(BaseFacetedSearchView):

form_class = FacetedProductSearchForm
facet_fields = ['ptags']
template_name = 'search_result.html'
paginate_by = 30
context_object_name = 'object_list'

И мой search_indexes.py

class ProductIndex(indexes.SearchIndex, indexes.Indexable):
text = indexes.EdgeNgramField(
    document=True, use_template=True,
    template_name='search/indexes/product_text.txt')
destination = indexes.CharField(model_attr="destination") #boost=1.125

# Tags
ptags = indexes.MultiValueField(model_attr='_ptags', faceted=True)

# for auto complete
content_auto = indexes.EdgeNgramField(model_attr='destination')

# Spelling suggestions
suggestions = indexes.FacetCharField()

def get_model(self):
    return Product

def index_queryset(self, using=None):
    """Used when the entire index for model is updated."""
    return self.get_model().objects.filter(timestamp__lte=timezone.now())

Есть идеи, как это исправить?

Большое спасибо!

1 Ответ

0 голосов
/ 23 июля 2020

Проблема, похоже, связана с самим Elasticsearch, поэтому я удалил все мои экземпляры Elasticsearch и переформулировал свое представление поиска в простые postgresql запросы.

Заключительное наблюдение после решения этой проблемы:

50 долларов в месяц, а поисковая система работает как шарм!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...