第一步:安装全文检索框架django-haystackdjango
pip3 install django-haystacksession
第二步:安装搜索引擎app
pip3 install whoosh框架
第三步:在settings配置app搜索引擎
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'haystack' #全文检索框架
'movie.apps.MovieConfig',
]
# 全文检索框架的配置
HAYSTACK_CONNECTIONS = {
'default': {
# 使用whoosh引擎
'ENGINE': 'haystack.backends.whoosh_backend.WhooshEngine',
# 索引文件路径(不须要手动建,会自动建)
'PATH': os.path.join(BASE_DIR, 'whoosh_index'),
}
}
# 当添加、修改、删除数据时,自动生成索引
HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.RealtimeSignalProcessor'
# 指定搜索结果每页显示的条数
HAYSTACK_SEARCH_RESULTS_PER_PAGE = 1
第 4 步:
定义索引类
# 定义索引类
from haystack import indexes
# 导入你的模型类
from movie.models import Movie
# 指定对于某个类的某些数据创建索引
# 索引类名格式:模型类名+Index
class MovieIndex(indexes.SearchIndex, indexes.Indexable):
# 索引字段 use_template=True指定根据表中的哪些字段创建索引文件的说明放在一个文件中
text = indexes.CharField(document=True, use_template=True)use_template=True说明在template文件下建索引文件
def get_model(self):
# 返回你的模型类
return Movie
# 创建索引的数据
def index_queryset(self, using=None):
return self.get_model().objects.all()
第五步:创建索引文件
在template文件下建索引文件,
第6步:
在索引文件goodssku_text.txt文件中写按照什么字段搜索
第7步:spa
第八步:使用全文检索
第9步:配置URL3d
第10步blog
第11步,更改分词方式:改成结巴分词索引