我正在使用 django haystack 在我的 django 项目中实现搜索系统。问题是我的模型中的某些字段有一些法语口音,我想找到包含和不带口音的查询的条目。
我认为最好的想法是创建一个 SearchIndex,其中包含带重音的字段和不带重音的相同字段。
对此有任何想法或提示吗?
这是一些代码
想象一下以下模型:
Cars(models.Model):
name = models.CharField()
和以下干草堆指数:
Cars(indexes.SearchIndex):
name = indexes.CharField(model_attr='name')
cleaned_name = indexes.CharField(model_attr='name')
def prepare_cleaned_name(self, object):
return strip_accents(object.name)
现在,在我的索引模板中,我把这两个字段:
{{ object.cleaned_name }}
{{ object.name }}
所以,这是一些伪代码,我不知道它是否有效,但如果您对此有任何想法,请告诉我!