专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > 数据库

elaticserach ik自定义远道词库的方法

发布时间:2010-05-20 14:01:29 文章来源:www.iduyao.cn 采编人员:星星草
elaticserach ik自定义远程词库的方法
这是ik的配置文件  在配置远程扩展字典写上下面方法的接口(要注意能调取到这个方法) 把停止词典注释掉
---------------------------------------------------------------------------
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE properties SYSTEM "http://java.sun.com/dtd/properties.dtd">
<properties>
<comment>IK Analyzer 扩展配置</comment>
<!--用户可以在这里配置自己的扩展字典 -->
<entry key="ext_dict">custom/mydict.dic;custom/single_word_low_freq.dic</entry>
<!--用户可以在这里配置自己的扩展停止词字典-->
<entry key="ext_stopwords">custom/ext_stopword.dic</entry>
<!--用户可以在这里配置远程扩展字典 -->
<entry key="remote_ext_dict">location</entry>
<!--用户可以在这里配置远程扩展停止词字典-->
<entry key="remote_ext_stopwords">http://xxx.com/xxx.dic</entry>
</properties>
---------------------------------------------------------------------------
以下是java代码部分
---------------------------------------------------------------------------
@GET
    @Path("loadGJCK")
    @Produces(MediaType.APPLICATION_OCTET_STREAM)
    @ApiOperation(value = "词库")
    public String  loadGJCK(@Context HttpServletRequest request,@Context HttpServletResponse response){
        String result = "";
        try {

            StringBuilder sb = new StringBuilder();
            String[] keywords = keywordService.selectKeyWord(10l);//获取所有分词,这里可以改进使用缓存等。

            String eTag = request.getHeader("If-None-Match");
            Long modified= request.getDateHeader("If-Modified-Since");

            //设置头
            if(null == modified || -1 == modified) {
                //如果没有,则使用当前时间
                modified = System.currentTimeMillis();
            }
            // 设置头信息。
            String oldEtag = keywords.length+ "";
            response.setDateHeader("Last-Modified", Long.valueOf(modified));
            response.setHeader("ETags", keywords.length + "");

            if(!oldEtag.equals(eTag)) {
                //拼装结果
                for(String tempWord : keywords) {
                    if(!StringUtils.isEmpty(tempWord)){
                        //分词之间以换行符连接
                        if(StringUtils.isNotEmpty(sb.toString())) {
                            sb.append("rn");
                        }
                        sb.append(tempWord);
                    }
                }
                //result = new String(result.getBytes("ISO8859-1"), "UTF-8");
                result = sb.toString();
                //更新时间
                response.setDateHeader("Last-Modified", System.currentTimeMillis());
            }

        }catch (Exception e){
            e.printStackTrace();
        }finally {
            System.out.println(result);
            return result;
        }
    }


然后这个词库就可以用啦!
1 楼 abao1 2017-08-07  
https://github.com/medcl/elasticsearch-analysis-ik
可以参考这个
友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: