本文首发于公众号:Hunter后端
原文链接:es笔记四之中文分词插件装置与应用

后面咱们介绍的操作及演示都是基于英语单词的分词,但咱们大部分应用的必定都是中文,所以如果须要应用分词的操作必定也是须要应用中分分词。

这里咱们介绍一下如何装置中文分词插件。

在介绍装置之前,咱们能够先来测试一下没有中文分词的分词成果,咱们先来插入一条数据:

PUT /exam/_doc/16{    "name" : "张三丰",    "address": "一个苹果"}

如果是中文分词,咱们能够想到 '一个苹果' 应该会被分为 '一个' 和 '苹果' 这两个词,然而默认的分词是无奈这样分词的,咱们能够尝试搜寻一下:

GET /exam/_search{  "query": {    "term": {      "address": "一个"    }  }}

能够发现是无奈搜寻到后果的。

咱们能够查看一下这条数据的 address 字段被分词的后果:

GET /exam/_doc/16/_termvectors?fields=address

其中,_doc 前面的 16 是咱们要查问的数据的 id,fields 前面跟着的要查看的分词后果的字段名。

能够看到 一个苹果 这个字符串,被挨个分成了四个。

而后咱们来装置一下中文分词的插件。

装置中文分词插件

在 elasticsearch 装置的目录下,执行上面的语句:

./bin/elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v7.6.0/elasticsearch-analysis-ik-7.6.0.zip

这里咱们装置的是 7.6.0 版本的 es,所以装置对应的分词插件。

而后咱们从新建设这个 index,为 address 字段加上指定的分词插件:

挨个执行上面的命令:

DELETE /exam/PUT /examPUT /exam/_mapping{  "properties": {    "address": {      "type": "text",      "analyzer": "ik_max_word",      "fields": {        "keyword": {          "type": "keyword",          "ignore_above": 256        }      }    },    "name": {      "type": "keyword"    }  }}

这里,和第一次创立 mapping 的时候比,多了一行 analyzer 的定义。

而后咱们再次反复下面的插入和查问操作:

PUT /exam/_doc/16{    "name" : "张三丰",    "address": "一个苹果"}GET /exam/_search{  "query": {    "term": {      "address": "一个"    }  }}

能够看到,这次咱们搜寻 一个,就能够查问到数据了。

而后咱们看下这条数据的 address 的分词后果:

GET /exam/_doc/16/_termvectors?fields=address

能够看到,这次返回的后果除了独自的 '一' 和 '个' 之外,还有被分成整体的 '一个' 和 '苹果'。

查看分词后果

这里额定介绍一下如何查看字符串的分词。

如果咱们有一个字符串,想要晓得它会被如何分词,能够间接应用上面的命令:

POST /_analyze{  "analyzer": "ik_smart",  "text": "一个苹果"}

其中,analyzer 是指定的分词的插件,如果不指定就会应用默认的分词性能。

中文分词插件的github 地址如下:https://github.com/medcl/elasticsearch-analysis-ik

如果想获取更多后端相干文章,可扫码关注浏览: