美文网首页
django-haystack(全文检索-jieba分词)

django-haystack(全文检索-jieba分词)

作者: 陈陈陈orz | 来源:发表于2018-03-25 16:54 被阅读0次

安装和配置

1.安装。

pip install django-haystack==2.6.1# 安装全文检索框架

pip install whoosh==2.7.4# 安装whoosh搜索引擎

2.配置。

在settings.py文件中添加如下配置:INSTALLED_APPS = (# ...'haystack',# 全文检索框架# ...)

# 全文检索框架配置

HAYSTACK_CONNECTIONS = {'default': {# 使用whoosh引擎'ENGINE':'haystack.backends.whoosh_backend.WhooshEngine',# 索引文件路径'PATH': os.path.join(BASE_DIR,'whoosh_index'),    }}

# 当添加、修改、删除数据时,自动生成索引

HAYSTACK_SIGNAL_PROCESSOR ='haystack.signals.RealtimeSignalProcessor'



索引文件生成

1.在goods应用目录下新建一个search_indexes.py文件,在其中定义一个商品索引类。

from haystack import indexes

from goods.models import GoodsSKU

#指定对于某个类的某些数据建立索引

class GoodsSKUIndex(indexes.SearchIndex, indexes.Indexable):

       text = indexes.CharField(document=True,use_template=True)

      def  get_model(self):

              return  GoodsSKU

      def  index_queryset(self, using=None):

          returnself.get_model().objects.all()

2.在templates下面新建目录search/indexes/goods。

3.在商品的目录下创建goodssku_text.txt。

4.在goodssku_text.txt中指定根据哪些字段建立索引。

5.在终端执行如下命令生成索引文件。

python manage.py rebuild_index



更改分词方式

1.安装jieba分词包。

pip install jieba

2.进入haystack目录

/home/python/.virtualenvs/dailyfresh/lib/python3.5/site-packages/haystack/backends/

3.在上面的目录中创建ChineseAnalyzer.py文件。

impor tjieba

from whoosh.analysis import Tokenizer, Token

class ChineseTokenizer(Tokenizer):

def__call__(self, value, positions=False, chars=False, keeporiginal=False, removestops=True,

start_pos=0, start_char=0, mode='', **kwargs):

t = Token(positions, chars, removestops=removestops, mode=mode, **kwargs)       

seglist = jieba.cut(value, cut_all=True)

for w in seglist:           

      t.original = t.text = w           

      t.boost =1.0

      if positions:              

            t.pos = start_pos + value.find(w)

       if chars:               

            t.startchar = start_char + value.find(w)               

            t.endchar = start_char + value.find(w) + len(w)

       yield  t

def  ChineseAnalyzer():

       return ChineseTokenizer()

4.复制whoosh_backend.py文件为如下名称。

  whoosh_cn_backend.py

5.打开whoosh_cn_backend.py,引入中文分析类,内部采用jieba分词。

from .ChineseAnalyzer  import  ChineseAnalyzer

6.更改whoosh_cn_backend.py文件中使用的词语分析类。

查找

analyzer=StemmingAnalyzer()

改为

analyzer=ChineseAnalyzer()

7.修改settings.py文件中的配置项。

8.重新创建索引数据。

python manage.py rebuild_index

相关文章

  • django-haystack(全文检索-jieba分词)

    安装和配置 1.安装。 pip install django-haystack==2.6.1# 安装全文检索框架 ...

  • elasticsearch和analysis-ik的安装使用

    全文搜索和中文分词主要介绍了两组全文搜索加中文分词方案;TNTSearch+jieba-php这套组合对于博客这类...

  • django中的全文检索

    全文检索 全文检索不同于特定字段的模糊查询,使用全文检索的效率更高,并且能够对于中文进行分词处理 haystack...

  • Django 2.1.7 全文检索

    全文检索 全文检索不同于特定字段的模糊查询,使用全文检索的效率更高,并且能够对于中文进行分词处理。 haystac...

  • 检索

    全文检索 全文检索不同于特定字段的模糊查询,使用全文检索的效率更高,并且能够对于中文进行分词处理。 haystac...

  • Django全文检索

    全文检索 全文检索不同于特定字段的模糊查询,使用全文检索的效率更高,并且能够对于中文进行分词处理' 安装 pip ...

  • python3中文jieba分词设置说明

    jieba分词的安装 在虚拟环境中 / 本地下安装 jieba jieba分词的配置 jieba中文分词的使用 进...

  • Django中全文检索(whoosh+jieba+haystac

    本文操作环境:whoosh 2.7.4 django-haystack 2.8.1 jieba 0.39...

  • 搜索引擎--全文检索

    全文检索不同于特定字段的模糊查询,使用全文检索的效率更高,并且能够对于中文进行分词处理。 haystack:全文检...

  • 结巴中文分词的用法

    jieba “结巴”中文分词:做最好的 Python 中文分词组件"Jieba" (Chinese for "to...

网友评论

      本文标题:django-haystack(全文检索-jieba分词)

      本文链接:https://www.haomeiwen.com/subject/kstkcftx.html