全文检索框架和搜索引擎的安装和配置:

  • 安装全文检索框架,pip install django-haystack,
  • 安装搜索引擎,pip install whoosh
  • settings里面配置
  • 1,注册haystack
  • INSTALLED_APPS=[
  • # 注册全文搜索框架
  • 'haystack',
  • ]
  • 2,配置,
  • # 全文检索框架的配置
    HAYSTACK_CONNECTIONS = {
    'default': {
    # 使用whoosh引擎
    # 'ENGINE': 'haystack.backends.whoosh_backend.WhooshEngine',
    'ENGINE': 'haystack.backends.whoosh_cn_backend.WhooshEngine',
    # 索引文件路径
    'PATH': os.path.join(BASE_DIR, 'whoosh_index'),
    }
    } # 当添加、修改、删除数据时,自动生成索引
    HAYSTACK_SIGNAL_PROCESSOR = 'haystack.signals.RealtimeSignalProcessor'

    这是一个路径:

  • 我找到Linux下面的路径:
  • /home/andy/.virtualenvs/lq_py3/lib/python3.5/site-packages/haystack/backends
  • 然后把我Windows下面的文件移动到这个地方,
  • 这里面有jieba分词的代码,

生成索引文件:

  • 搜索的是商品表的数据,
  • 你要有索引文件的生成,最终是需要goossku这个类,新建一个这个类的一个索引类,
  • 在templates下面建立文件夹search,下面建立indexes,这两个文件名都是固定的,
  • 下面再建立goods文件夹,建立索引文件,
  • 现在就可以生成索引数据了,
  • >python manage.py rebuild_index

全文检索的应用:

  • 两个地方,
  • 1,是页面上搜索的地方要有一个提交搜索的目标路径,
  • 2,是后台路由需要配置这个路径,这个是交给haystack来处理的,
  • 还需要一个搜索结果页的html页面,

更改分词的方式:

  • 比如,很不错的草莓,
  • 但是你搜索不错,这是查不到的,
  • 所以默认whoosh里面的引擎,在分解词语的时候分词不好,有些词分的不好,
  • 我们要使用一个中文分词的包,就是jieba分词,这是中文默认的分词,比默认的要好,
  • 这个分词怎么用:
  • 第一步:安装
  • 安装,pip install jieba,
  • 有什么用?下面就是演示:
  • import jieba,
  • srt=‘很不错的草莓’
  • res=jieba.cut(str,cut_all=True)
  • for val in res:
  • print(val)

  • 不错

    草莓

  • 这就是分词的结果,很不错,
  • 那么怎么用呢?
  • 第二步:在haystack目录新建一个文件,
  • 还是进入Linux中,haystack的目录下:
  • /home/andy/.virtualenvs/lq_py3/lib/python3.5/site-packages/haystack/backends
  • 然后把Windows下面的文件ChineseAnalyzer.py复制一份到这个地方,
  • 然后就可以了,
  • 1,安装
  • 2,新建一个文件,
  • 3,修改文件,
  • 4,修改配置,
  • 5,重新建立索引,这次就是使用jieba分词了

python-django项目基础-haystack&whoosh&jieba_20191124的更多相关文章

  1. Python(Django)项目与Apache的管理

    (开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...

  2. Python(Django)项目与Apache的管理交互

    (开开心心每一天~ ---虫瘾师) Python(Django)项目交给Apache的管理(一) 准备:Django的环境(Python).Apache.Wsgi(必须文件) 首先需要电脑有Pytho ...

  3. Python Django项目日志查询系统

    该项目适合中小型公司日志查询工作.大型公司可以使用elk等.该系统其实就是调用了absible命令去查日志,然后把输出的信息输到页面查看. 日志查询系统 维护手册 作者:陈土锋 日期:2020年6月1 ...

  4. 使用Nginx+uwsgi在亚马逊云服务器上部署python+django项目完整版(二)——部署配置及相关知识

    ---恢复内容开始--- 一.前提: 1.django项目文件已放置在云服务器上,配置好运行环境,可正常运行 2.云服务器可正常连接 二.相关知识 1.python manage.py runserv ...

  5. 小试VS 2017 开发Python Django项目过程一

    一.新建项目python ->django web 项目 (选择带bootstrap风格与twwriter)项目名称iepiececomputing (ie计件计算)跳出窗体 -> 添加虚 ...

  6. Python Django项目部署 Linux 服务器

    项目依赖: Linux Centos7 (阿里云轻量级服务器) + Python 3.7.2 + Django 2.2.1 + restframework 3.9.4 + mysql 5.7 1 安装 ...

  7. python - django 项目部署 Ubuntu 服务器后接口访问一直 502 问题

    问题描述:最近有了一台 Ubuntu 的服务器,然后准备部署个项目,结果没想到部署的过程跟用 Centos 的时候还有点不一样,最后一步我是卡在了 uwsgi 这里,访问一直502,且可以访问项目的静 ...

  8. python django项目创建及前期准备(使用pycharm)

    一.创建django项目 1.打开pycharm软件 2.点击菜单栏 File-->New Project,弹出如下对话框,如下图设置 二.基本配置 1.静态文件目录配置(用于客户端访问后台服务 ...

  9. Django项目基础配置和基本使用

    博文配置内容包括: django项目的创建 django项目下应用的创建及配置 数据库的配置 templates模板的配置 命令行创建项目: 在需要的目录下创建Django项目输入命令:django- ...

随机推荐

  1. 直击JDD | 京东技术全景图首次展示 四大重磅智能技术驱动产业未来!

    11月19日,主题为"突破与裂变"的2019京东全球科技探索者大会(JDDiscovery)在京盛大开幕,京东集团展示了完整的技术布局与先进而丰富的对外技术服务,对外明确诠释了&q ...

  2. Linux中Tomcat 自动设置CATALINA_HOME方法

    Linux中Tomcat 自动设置CATALINA_HOME方法 在服务器部署中,我们经常会出现“在一个服务器上运行多个tomcat服务”的情况. 使用如下方法设置,可以无限复制平移扩展Tomcat, ...

  3. UML-GRASP前5种模式

    1.创建者(Creator) 问题:谁创建类A? 答:来自领域模型.设计模型(交互图.类图) 2.信息专家 问题:给对象分配职责的基本原则是什么? 回答:谁具有完成该职责的信息,谁负责该职责. 因为根 ...

  4. Fidder IOS抓包

    Fiddler-HTTPS配置 手机抓包配置 手机网络配置 打开Safari浏览器输入IP+端口号:192.168.0.14:8888,安装证书 证书信任设置:通用 - 关于本机 - 证书信任设置 - ...

  5. python语法基础-并发编程-进程-进程理论和进程的开启

    ############################################## """ 并发编程的相关概念: 进程 1,运行中的程序,就是进程,程序是没有生 ...

  6. 2020 年最流行的 Java 开发技术

    不知不觉间,2020 年即将于十几天之后到来,作为技术圈中你,准备好迎接最新的变化了吗?在本文中,我们将以编程界最常用的编程语言 Java 为例,分享最为主流的技术与工具. 作者 | divyesh. ...

  7. Thread--对象锁猜想

    堆内存地址未发生变化: 对象堆内存地址没发生变化的情况下,即值是否与变仍然是同一把锁. 堆内存地址变化: 在线程尝试进入过同步代码时复制当前对象锁副本. 在复制对象锁副本之后改变对象指向不影响对象锁, ...

  8. Red Hat、Fedora和Ubuntu软件包操作

    五.Red Hat.Fedora和Ubuntu软件包操作对比 最后总结: 在 /etc/yum.conf 的 [main] 后面添加以下配置即可! 复制代码 代码如下: exclude=kernel* ...

  9. 怎样在 Akka Persistence 中实现分页查询

    在 Akka Persistence 中,数据都缓存在服务内存(状态),后端存储的都是一些持久化的事件日志,没法使用类似 SQL 一样的 DSL 来进行分页查询.利用 Akka Streams 和 A ...

  10. Xpath编码问题解决

    使用Xpath获取属性时,出现乱码问题,解决办法找了好多,终于解决,特将办法贴在这,供大家尝试 不要直接简单的将爬取的网页设置为utf-8, 先通过print(r.encoding)输出看看爬取的是什 ...