文章目录

  • 一、全文检索和搜索引擎原理
    • 1.商品搜索需求
    • 2.商品搜索实现
    • 3.全文检索方案
    • 4.搜索引擎原理
  • 二、Elasticsearch介绍
  • 三、Docker安装Elasticsearch
  • 四、haystack扩展建立索引
    • 1. Haystack介绍和安装配置
      • 1.1 Haystack介绍
      • 1.2 Haystack安装
      • 1.3 Haystack注册应用和路由
      • 1.4测试
  • 五、自定义页面访问
    • 1.创建索引类
    • 2.创建序列化器
    • 3.最后创建建立索引的数据
    • 4.创建视图
    • 5.创建索引的序列器
    • 6.在我们应用的路由中进行注册

一、全文检索和搜索引擎原理

1.商品搜索需求

当用户在搜索框输入商品关键字后,我们要为用户提供相奂的商品搜索结果。

2.商品搜索实现

可以选择使用模糊查询like突键字实现。

但是like关键字的效率极低。

查询需要在多个字段中进行,使用like关键字也不方便。

3.全文检索方案

我们引入全文检索的方案来实现商品搜索。

全文检索即在指定的任意字段中进行检索查询。

全文检索方案需要配合搜索引擎来实现。

4.搜索引擎原理

搜索引擎进行全文检索时,会对数据库中的数据进行一遍预处理,单独建立起一份索引结构数据。

索引结构数据类似新华字典的索引检索页,里面包含了关键词与词条的对应失系,并记录词条的位置。

搜索引擎进行全文检索时,将关键字在索引数据中进行快速对比查找,进而找到数据的真实存储位置。

二、Elasticsearch介绍

实现全文检索的搜索引擎,首选的是Elasticsearch。

  • Elasticsearch是用Java实现的,开源的搜索引擎。
  • 它可以快速地储存、搜索和分析海量数据。维基百科、Stack Overflow Github等都采用它。
  • Elasticsearch的底层是开源库Lucene。但是,没法直接使用Lucene,必须自己写代码去调用它的接口。

分词说明

  • 搜索引擎在对数据构建索引时,需要进行分词处理。
  • 分词是指将一句话拆解成多个单字或词,这些字或词便是这句话的奂键词。 比如:我是中国人
  • 分词后:我、是、中、国、人、中国等等都可以是这句话的关键字。
  • Elasticsearch不支持对中文进行分词建立索引,需要配合扩展elasticsearch-analysis-ik来实现中文

三、Docker安装Elasticsearch

获取镜像,可以通过网络pull

docker image pull delron/elasticsearch-ik:2.4.6-1.0

或者用自己拉取好的镜像文件:

docker load -i elasticsearch-ik-2.4.6_docker.tar

修改elasticsearch的配置文件 elasticsearc-2.4.6/config/elasticsearch.yml第54行,更改ip地址为本机ip地址

network.host: 127.0.0.1

创建docker容器运行

docker run -dti --network=host --name=elasticsearch -v /home/python/elasticsearch-2.4.6/config:/usr/share/elasticsearch/config Desktop/elasticsearch-ik:2.4.6-1.0


出现如下表示服务已经成功运行了

四、haystack扩展建立索引

1. Haystack介绍和安装配置

1.1 Haystack介绍

  • Haystack是在Django中对接搜索引擎的框架,搭建了用户和搜索引擎之间的沟通桥梁。
  • 我们在Django中可以通过使用Haystack来调用Elasticsearch搜索引擎。
  • Haystack可以在不修改代码的情况下使用不同的搜索后端(比如Elasticsearch、whoosh、Solr等等)。

1.2 Haystack安装

pip install django-haystack
pip install elasticsearch==2.4.6

1.3 Haystack注册应用和路由

应用配置中加上如下应用

INSTALLED_APPS = ["haystack',#全文检索
]# Haystack
HAYSTACK_CONNECTIONS = {'default': {'ENGINE': 'haystack.backends.elasticsearch_backend.ElasticsearchSearchEngine','URL': 'http://127.0.0.1:9200/',  # 此处为elasticsearch运行的服务器ip地址,端口号固定为9200'INDEX_NAME': 'xxshopping',  # 指定elasticsearch建立的索引库的名称},
}# 当添加、修改、删除数据时,自动生成索引
HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.RealtimeSignalProcessor'

创建search_indexes.py在对应的商品目录下

from haystack import indexesfrom apps.goods.models import SKUclass SKUIndex(indexes.SearchIndex,indexes.Indexable):# 每个都SearchIndex需要有一个(也是唯一一个)字段 document=True。# 这向Haystack和搜索引擎指示哪个字段是用于在其中搜索的主要字段。#允许我们使用数据模板(而不是容易出错的串联)来构建搜索引擎将索引的文档# 'name,caption,id'#惯例是命名此字段texttext = indexes.CharField(document=True, use_template=True)def get_model(self):# 返回对哪个模型进行检索return SKUdef index_queryset(self, using=None):#对哪些数据进行检索return self.get_model().objects.filter(is_launched=True)# return self.get_model().objects.all()# return SKU.objects.all()# pass# class SPUIndex(indexes.SearchIndex, indexes.Indexable):
#     # 每个都SearchIndex需要有一个(也是唯一一个)字段 document=True。
#     # 这向Haystack和搜索引擎指示哪个字段是用于在其中搜索的主要字段。
#
#     # 惯例是命名此字段text
#     text = indexes.CharField(document=True, use_template=True)

在模板里新建sku_text.txt文件

# 在这里我们指定 对模型的哪些字段进行检索
# object 可以理解为 SKU的实例对象{{ object.name }}
{{ object.caption }}
{{ object.id }}

在全局路由文件下添加

re_path('^search/', include('haystack.urls'))

添加视图search.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"><title>小徐商城-商品搜索</title><link rel="stylesheet" type="text/css" href="{{ static('css/jquery.pagination.css') }}"><link rel="stylesheet" type="text/css" href="{{ static('css/reset.css') }}"><link rel="stylesheet" type="text/css" href="{{ static('css/main.css') }}"><script type="text/javascript" src="{{ static('js/jquery-1.12.4.min.js') }}"></script><script type="text/javascript" src="{{ static('js/vue-2.5.16.js') }}"></script><script type="text/javascript" src="{{ static('js/axios-0.18.0.min.js') }}"></script>
</head>
<body><div id="app"><div class="header_con"><div class="header" v-cloak><div class="welcome fl">欢迎来到小徐商城!</div><div class="fr"><div v-if="username" class="login_btn fl">欢迎您:<em>[[ username ]]</em><span>|</span><a href="#">退出</a></div><div v-else class="login_btn fl"><a href="#">登录</a><span>|</span><a href="#">注册</a></div><div class="user_link fl"><span>|</span><a href="#">用户中心</a><span>|</span><a href="#">我的购物车</a><span>|</span><a href="#">我的订单</a></div></div></div></div><div class="search_bar clearfix"><a href="{{ url('contents:index') }}" class="logo fl"><img src="{{ static('images/logo.png') }}"></a><div class="search_wrap fl"><form method="get" action="/search/" class="search_con"><input type="text" class="input_text fl" name="q" placeholder="搜索商品"><input type="submit" class="input_btn fr" name="" value="搜索"></form><ul class="search_suggest fl"><li><a href="#">索尼微单</a></li><li><a href="#">优惠15元</a></li><li><a href="#">美妆个护</a></li><li><a href="#">买2免1</a></li></ul></div></div><div class="main_wrap clearfix"><div class=" clearfix"><ul class="goods_type_list clearfix">{% for result in page %}<li>{# object取得才是sku对象 #}<a href="#"><img src="{{ result.object.default_image.url }}"></a><h4><a href="#">{{ result.object.name }}</a></h4><div class="operate"><span class="price">¥{{ result.object.price }}</span><span>{{ result.object.comments }}评价</span></div></li>{% else %}<p>没有找到您要查询的商品。</p>{% endfor %}</ul><div class="pagenation"><div id="pagination" class="page"></div></div></div></div><div class="footer"><div class="foot_link"><a href="#">关于我们</a><span>|</span><a href="#">联系我们</a><span>|</span><a href="#">招聘人才</a><span>|</span><a href="#">友情链接</a></div><p>CopyRight © 2016 小徐 All Rights Reserved</p><p>电话:010-****888    京ICP备*******8号</p></div></div><script type="text/javascript" src="{{ static('js/common.js') }}"></script><script type="text/javascript" src="{{ static('js/search.js') }}"></script><script type="text/javascript" src="{{ static('js/jquery.pagination.min.js') }}"></script><script type="text/javascript">$(function () {$('#pagination').pagination({currentPage: {{ page.number }},totalPage: {{ paginator.num_pages }},callback:function (current) {window.location.href = '/search/?q=iphone&amp;page=1';window.location.href = '/search/?q={{ query }}&page=' + current;}})});</script>
</body>
</html>

最后创建建立索引的数据:

python manage.py rebuild_index

选 y

此时, 在我们的数据库中就有了我们索引的数据;

1.4测试

/search/?q=查询产生

五、自定义页面访问

1.创建索引类

2.创建序列化器

3.最后创建建立索引的数据

python manage.py rebuild_index

选Y

4.创建视图

5.创建索引的序列器

6.在我们应用的路由中进行注册


最后就是设置我们前端的search.html 的页面,及对应的js加载文件;

【愚公系列】2022年02月 Django商城项目 26-搜索引擎功能实现相关推荐

  1. 【愚公系列】2022年02月 Django商城项目 34-订单支付功能实现(支付宝)

    文章目录 前言 一.回调逻辑处理 1.安装SDK 2.生成私钥公钥 3.setting中支付宝配置信息 4.生成支付URL 5.接收支付成功信息 前言 具体支付宝支付流程可参考这篇文章:https:/ ...

  2. 【愚公系列】2022年01月 Django商城项目13-登录界面-QQ登录功能实现

    文章目录 前言 1.QQ互联开发者申请 2.QQ互联应用申请 3.网站对接QQ登录 一.django实际对接流程 1.创建抽象模型类 2.创建QQ用户模型类 3.注册应用 4.配置QQ登录信息 5.登 ...

  3. 【愚公系列】2022年01月 Django商城项目 24-商品列表页功能实现

    文章目录 一.商品列表页功能实现 1.后台查询代码 二.面包屑信息展示 1.前台html代码 2.实际效果 三.列表页信息展示 1.前台html代码 2.实际效果 一.商品列表页功能实现 1.后台查询 ...

  4. 【愚公系列】2022年01月 华为鸿蒙OS-03-四种模式开发实操

    文章目录 前言 一.使用JS语言开发(传统代码方式) 1.index页面源码 2.details页面源码 二.使用JS语言开发(低代码方式) 1.新建工程:注意选择 2.选择低代码新建页面 3.页面分 ...

  5. 滚动测试报告 2022年02月

    SpeechIO的所有历史文章可在语音之家网站的[声浪]-[SpeechIO专区]查看,评测结果数据可在语音之家(PC端)的[评测]页面查看. 官网地址:http://www.speechhome.c ...

  6. 【愚公系列】回顾2022年技术博客的总结与展望

    文章目录 前言 一.回顾2022年的活动和成就 1.2022年所做的事 2.2022年收获和成就 二.分析2022年的表现 1.过去一年优缺点分析 2.过去一年表现认同度 三.展望2023年的计划 1 ...

  7. 【愚公系列】(HDC.Cloud)华为开发者大会游记

    文章目录 前言 一.(HDC.Cloud)华为开发者大会游记 1.受邀参加 2.开发者大会首页 3.第一天 4.第二天 5.第三天 总结 前言 HDC.Cloud华为开发者大会是由华为举办的一年一度的 ...

  8. 【愚公系列】华为产品测评官-开发者之声(CodeArts产品流程体验)

    文章目录 前言 一.华为云CodeArts产品体验 1.软件开发生产线使用流程 1.1 配置项目 1.2 配置代码仓库 1.3 配置流水线 2.使用软件开发生产线快速搭建项目(ECS篇) 2.1 前提 ...

  9. 【shopify 1】调研出海项目,发现shopify没有java的相关SDK接口,但是找到一个最新2022年6月的Java项目分享了相关代码,使用docker进行环境搭建、编译,并成功启动

    目录 前言 1,关于shopify java调研 2,发现一个新的关于shopify的JavaSDK开源项目是2022年6月发布的 3,使用OAuth2 进行授权的逻辑 4,解决相关问题,解决配置依赖 ...

  10. 【愚公系列】2022年02月 U3D全栈班 005-Unity引擎视图

    文章目录 一.引擎视图 1.Project:项目视图 2.Hierarchy:结构视图 3.Inspector:检查器 4.Scene:场景 5.Game:游戏画面 6.Console:控制台 总结 ...

最新文章

  1. 【Android APT】注解处理器 ( 根据注解生成 Java 代码 )
  2. 双向链表删除节点时间复杂度_删除链表的节点(剑指offer第十七题)
  3. TLD(Tracking-Learning-Detection)学习与源码理解之(二)
  4. Docker多阶段镜像构建Dockerfile脚本示例:构建nodejs前端项目
  5. Archsummit 2019重磅分享|闲鱼Flutter&FaaS云端一体化架构
  6. --c语言运算符_C按位运算符-能力问题和解答
  7. div设置高度 vue_VsCode常用设置(新手必备!)
  8. 调整DOSBOX窗口大小
  9. 散粉在哪个步骤用_无限回购的散粉
  10. 求解一元二次方程,包含复数解
  11. JavaEE进阶——Spring学习笔记
  12. Tensorflow中的masking和padding
  13. 〖Windows〗三星(SAMSUNG)905S3G-K07 安装Windows 7 过程分享
  14. 压电传感器用于车辆测速和承重、车型识别
  15. R语言 自定义区间频数频率表
  16. 封禁、下架!微信出手了,规范整治数字藏品平台!
  17. layui xm-select的使用
  18. HSIC转USB国产芯片 宸芯科技模块调试案例分享
  19. 如何快速修改SQLite生成的.db文件(SQLite)
  20. 2023年二月TIOBE编程语言排行榜TIOBE Index for February 2023

热门文章

  1. python info函数的使用方法_Python 函数
  2. launchpad乐器_PreSonus 发布 ATOM 打击垫控制器(视频)
  3. RC有源滤波器之低通滤波器(一)
  4. QT多线程,使用串口接收数据通过UDP端口进行数据转发
  5. oracle dbv验证,ORACLE施用dbv工具检验数据文件是否有坏块
  6. JavaScript学习手册一:JS简介
  7. Android fragment原因,Android总结之Fragment
  8. java高级工程师个人简历模板
  9. c语言json数据转换成字符串,C语言将字符串转json
  10. 爬虫 | 破解APP中阿里云滑动验证码