codecamp

自定义 SCWS 词库

如之前所说,我们所有的索引分词器默认为 scws,这也是我们开发的开源分词系统, 内置的词库基本上能满足绝大多数应用。但总有例外,这也就是即将说的如何自定义词库。

1. 全局自定义词库

这是针对同一个 xunsearch 安装实例来讲,该服务端下的所有项目都将共用这个自定义词库。 严格来讲,这是 SCWS 本身就提供的功能,xunsearch 只是做了整合和规范。涉及的相关文件如下 (假设 $prefix 是您的安装目录)

$prefix/etc/dict_user.txt

打开上述文件,文件开头已经有了相关注释和说明。这个文件就是自定义词库文件, 如果您同一台机器上装有多个 xunsearch 服务端,那么每个服务端独自使用自己的自定义词典文件。

添加删除修改自定义词库只要编辑该文件即可,以下为相关规范:

  • 文件为纯文本文件,编码必须是 UTF-8,可用任何编辑器修改

  • 每行一条记录表示一个词,每行包含 1~4 个字段,字段之间用空格或制表符(\t)分隔

  • 字段含义依次表示 “词语”,“词频(TF)”,“逆词频率(IDF)”,“词性(ATTR)”

  • 后面三个字段如果省略依次使用 scws 的默认值

  • 特殊词性 ! 可用于表示删除该词

  • 自定义词典优先于内置词典加载和使用,以 # 开头的行为注释

Note: 该功能自 1.2.0 版本起方可使用,源自网友建议。

2. 项目自定义词库

某些情况下,不同的项目需要不同的特殊词库。每个搜索项目的自定义词库文件如下:

$prefix/data/项目名称/dict_user.txt

文件内容及格式与全局自定义词库是一致的,在此不再赘述。此外,这个文件还可以通过相关的 SDK API 读取和修改。

  • XSIndex::getCustomDict 读取当前项目的自定义词库内容,若不存在则返回空字符串

  • XSIndex::setCustomDict 设置当前项目的自定义词库内容,格式参见上面文档

Note: 该功能自 1.3.4 版本起方可使用。


使用索引缓冲区
搜索概述
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

了解基础对象方法

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }