首页 > 其他 > 详细

不启动Solr,使用Solr的analyzer chain (使用mmseg4j分词)

时间:2016-04-07 10:55:50      阅读:251      评论:0      收藏:0      [点我收藏+]

这个本质上还是Lucene的analyzer chain,Solr的只是方便了使用:通过配置xml文件就可以把tokenizer和filter链接起来。我们有时候需要在自己代码里使用这个chain。本文记录怎么做。

先看整体代码 (groovy):

class MyAnalyzer {
    def analyzer = new Analyzer() {
        @Override
        protected TokenStreamComponents createComponents(String s) {
            def loader = new ClasspathResourceLoader()

            // create tokenizer
            def factory = new MMSegTokenizerFactory(["mode": "complex", "dicPath": "dict"])
            factory.inform(loader)
            Tokenizer tokenizer = factory.create()

            // create tokenfilters
            factory = new SynonymFilterFactory(["synonyms": "dict/synonyms.txt", "expand": "true", "ignoreCase": "true"])
            factory.inform(loader)
            TokenFilter filter = factory.create(tokenizer)

            factory = new StopFilterFactory(["ignoreCase": "true", "words": "dict/stop_words_cn.txt"])
            factory.inform(loader)
            filter = factory.create(filter)

            return new TokenStreamComponents(tokenizer, filter)
        }
    }

    def tokenize(String text) {
        def tokens = []
        def ts = analyzer.tokenStream("text", text)
        def termAttr = ts.addAttribute(CharTermAttribute.class)
        ts.reset()
        while (ts.incrementToken()) {
            tokens.add(termAttr.toString())
        }
        ts.end()
        ts.close()
        return tokens
    }
    
    public static void main(String[] args) {
        MyAnalyzer analyzer = new MyAnalyzer()
        println(analyzer.tokenize("我是一个粉刷匠"))
    }
}

有几个关键点:

  1. 自定义的analyzer要集成Analyzer,并实现createComponents方法

  2. 需要resourceLoader来加载数据文件

  3. 上面链接了三个,可以更多:TokenizerFactory, SynonymFilterFactory, StopFilterFactory...

  4. 取token的方法比较特殊:需要用一个Attribute类: CharTermAttribute;需要操作tokenStream

    必须要按这样的流程(lucene规定。。。):reset, incrementToken, end, close

本文出自 “我劝天公重抖擞” 博客,请务必保留此出处http://waynecui.blog.51cto.com/8231128/1761156

不启动Solr,使用Solr的analyzer chain (使用mmseg4j分词)

原文:http://waynecui.blog.51cto.com/8231128/1761156

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!