- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 elasticsearch 和 haystack 来提供搜索。我希望用户使用英语以外的语言进行搜索。例如。目前正在尝试使用希腊语。
在搜索任何内容时如何忽略重音。例如。假设我输入 Ανδρέας (带重音符号),其返回结果与之匹配。
但是当我输入 Ανδρεας 时,它没有返回任何结果。搜索引擎应该带来任何带有“Ανδρέας”和“Ανδρεας”的结果(第二个没有重音)。
有人可以指出如何解决问题吗?
如果我需要 Elasticsearch 、search_indexex 等的帖子设置,请告诉我。
编辑:
这是我的索引设置:
ELASTICSEARCH_INDEX_SETTINGS = {
'settings': {
"analysis": {
"analyzer": {
"myanalyzer_search": {
"type": "custom",
"tokenizer": "standard",
"filter": [
"greek_lowercase_filter",
"my_stop_filter",
"greek_stem_filter",
"english_stem_filter",
"my_edge_ngram_filter",
"asciifolding"
]
},
"myanalyzer_index": {
"type": "custom",
"tokenizer": "edgeNGram",
"filter": [
"greek_lowercase_filter",
"my_stop_filter",
"greek_stem_filter",
"english_stem_filter",
"my_edge_ngram_filter",
"asciifolding"
]
},
},
"tokenizer": {
"my_edge_ngram_tokenizer": {
"type": "edgeNGram",
"min_gram": "2",
"max_gram": "18",
"token_chars": ["letter"]
}
},
"filter": {
"my_edge_ngram_filter": {
"type": "edgeNGram",
"min_gram": 3,
"max_gram": 18
},
"greek_stem_filter": {
"type": "stemmer",
"name": "greek"
},
"greek_lowercase_filter": {
"type": "lowercase",
"language": "greek"
},
"english_stem_filter": {
"type": "stemmer",
"name": "english"
},
"my_stop_filter": {
"type": "stop",
"stopwords": ["_greek_", "_english_"]
}
}
}
}
}
search_index.py
:
class ProfileIndex(indexes.SearchIndex, indexes.Indexable):
text = indexes.EdgeNgramField(document=True, use_template=True)
title = indexes.CharField(model_attr='title')
sorted_title = indexes.CharField(model_attr='title', indexed=False, stored=True)
employment_history = indexes.EdgeNgramField(model_attr='employment_history', null=True)
def get_model(self):
return SellerProfile
def index_queryset(self, using=None):
return self.get_model().objects.all()
.........
{{ object.user.get_full_name }}
{{ object.title }}
{{ object.bio }}
{{ object.employment_history }}
{{ object.education }}
results = SearchQuerySet().model(Profile).autocomplete(text='Ανδρεας')
results = SearchQuerySet().model(Profile).autocomplete(text='Ανδρέας')
最佳答案
您需要添加 asciifolding
token 过滤器为您分析/查询管道 http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/analysis-asciifolding-tokenfilter.html
这基本上从您的单词中删除了任何重音,以便您以后可以轻松地找到它们,无论是否使用重音搜索。
关于elasticsearch - 使用 haystack 忽略 Elasticsearch 中的重音,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23593770/
我正在阅读 Haystack 的“入门”指南,并尝试使用 Haystack 为我的网站实现 Whoosh 后端。我成功设置了整个项目,还可以在我的 search.html 模板上看到搜索框。我无法建立
我正在尝试使用 django haystack 制作自定义搜索表单,我只是从 haystack 的文档中修改: 表格.py from django import forms from haystack
我是 Django 和 Haystack 的新手...我需要知道如何按日期/时间戳对搜索结果进行排序,最近的排在最前面。 这是我的模型.py: class adsText(models.Model):
我在一个应用程序中使用 Haystack,它非常完美。它正在索引我需要的一切。但是,现在我创建了另一个应用程序,具有不同的模型和内容,我想用 Haystack 索引它。我的想法是在我的网站上创建两个不
我想根据返回的不同模型名称(类)对结果进行分面。是否有捷径可寻? 最佳答案 您是否尝试添加 SearchIndex字段与此信息?例如。 class NoteIndex(SearchIndex, ind
我想在我博客的 base.html 模板上使用 django-haystack 的搜索表单,但结果在不同的模板页面上,我该怎么做? 最佳答案 构造表单以将数据提交到正确的 URL,
我使用 Haystack 进行搜索,返回的结果 SearchQuerySet 包含 None 元素: >> SearchQuerySet().models(Question, Document, Id
我在 Django 中使用 Haystack 和 Whoosh 在 search_index.py 我有这个 class PageIndex(RealTimeSearchIndex): tex
我正在使用 Haystack和 Whoosh使用来自 Geonames 的城市数据搜索自定义应用程序项目。 我只导入了少量 Geonames 城市数据(22917 条记录)。我想按城市人口对结果进行排
我将 Django 1.5.1 与 django-haystack 2.1.0 和 whoosh 2.5.2 后端一起使用: 模型.py: GENDER_CHOICES = ( (u'M',
我在生产服务器上安装 django-haystack 时遇到问题。 当我运行以下任何命令时,出现错误No module named haystack: python manage.pysyncdb p
我正在尝试为只搜索单词的一部分(如果我没记错的话,根据 Haystack 文档称为 autocomplete)实现生成结果。 示例: 搜索 "gol" 结果 "goldfish" 我尝试了什么? 我按
我在 Django Haystack 1.2.5 中遇到了一些问题。我需要提升一个领域,但显然它不起作用。我正在使用 Solr 1.4.1。 我的指数: class JobsTextIndex(ind
我有两个模型: 模型.py class model1 (models.Model): field1_model1 = models.CharField() filed2_model1 =
我正在尝试获取 MultiValueField被索引,但它只是不工作。这是我所拥有的: 类 Public_PollIndex(SearchIndex): text = CharField(model_
我已经使用 Django Haystack 一段时间了,它很棒!我有一个相当繁重的网站,其中的数据需要不时更新(15 到 30 分钟)。 使用 python manage.py update_inde
有没有办法制作 django-haystack 的 {% highlight %}模板标签显示传入的完整变量,而不是在第一次匹配之前删除所有内容? 我是这样使用它的: {% highlight thr
在我的领域中,内容是“示例”。我不仅想找到确切的单词“example”,我还想找到“examp”。我怎样才能做到这一点?有没有选择。找不到任何东西。 最佳答案 如果您只想搜索以某个字符串开头的对象,那
我已经使用 Solr 在 Haystack 中正确配置了拼写建议的所有内容,但是,当使用 SearchView 时,suggestion 上下文变量未设置。我意识到这是由于 https://githu
使用elasticsearch(2.x),django-haystack(2.8.0),drf-haystack(1.8.6)我建立了搜索。一切工作正常,除了我不能同时搜索多个字段。现在,我只能搜索(
我是一名优秀的程序员,十分优秀!