自各儿动手写搜索引擎(常搜吧历程三#分词#)(Java、Lucene、hadoop)
自己动手写搜索引擎(常搜吧历程三#分词#)(Java、Lucene、hadoop)
对于初学者,我们只需要掌握这些经典的分词器就足够了。
大家通过这个例子可以看到,padoding分词器相当的强大,在此我们也不过多介绍,有兴趣的朋友可以看解压后的中文操作手册。
分词的基本原理:
1、分词是用来对文本按语言特征按算法进行过滤、分组处理的一种技术。
2、分词的对象是文本,而不是图像动画脚本等等。
3、分词的方式就是过滤和分组。
4、过滤主要把文本中那些没有实际意义的字或词过滤掉。
5、分组就是按照”分词数据库“内已添加好的词,进行匹配。
下面来看Lucene分词器的使用
package com.qianyan.analyzer; import java.io.IOException; import java.io.StringReader; import org.apache.lucene.analysis.Analyzer; import org.apache.lucene.analysis.SimpleAnalyzer; import org.apache.lucene.analysis.Token; import org.apache.lucene.analysis.TokenStream; import org.apache.lucene.analysis.WhitespaceAnalyzer; import org.apache.lucene.analysis.cjk.CJKAnalyzer; import org.apache.lucene.analysis.cn.ChineseAnalyzer; import org.apache.lucene.analysis.standard.StandardAnalyzer; public class TestAnalyzer { public static void main(String[] args) throws IOException { Analyzer analyzer = new StandardAnalyzer(); //标准 过滤停用次 //Analyzer analyzer = new SimpleAnalyzer(); //简单 过滤空格和符号 //Analyzer analyzer = new WhitespaceAnalyzer(); //过滤空格 //Analyzer analyzer = new ChineseAnalyzer(); //lucene下的中文分词器 拆分每个字符,过滤符号 //Analyzer analyzer = new CJKAnalyzer(); //中文 两字两字拆分 英文和standard功能一样 String input = "this is test lucene analyzer class!"; TokenStream tokenStream = analyzer.tokenStream("", new StringReader(input)); Token token = new Token(); while(null != tokenStream.next(token)) System.out.println(token.term()); } }
对于初学者,我们只需要掌握这些经典的分词器就足够了。
但在实际的开发过程中,满足我们需要得,是一些基于lucene分词之上的第三方中文分词包,在这里我们只介绍 ”庖丁分词包“,命令借鉴了”庖丁解牛“这个成语。
庖丁解牛,我国古代成语,出自《庄子》,比喻经过反复实践,掌握了事物的客观规律,做事得心应手,运用自如。
下载网址链接:http://code.google.com/p/paoding/
解压后我们需要对项目添加2个jar包,解压目录下的paoding-analysis.jar 和lib下的 commons-logging.jar 。令把dic文件夹复制到我们的项目src目录下。
package com.qianyan.analyzer; import java.io.IOException; import java.io.StringReader; import net.paoding.analysis.analyzer.PaodingAnalyzer; import org.apache.lucene.analysis.Analyzer; import org.apache.lucene.analysis.Token; import org.apache.lucene.analysis.TokenStream; public class TestPaodingAnalyzer { public static void main(String[] args) throws IOException { Analyzer analyzer = new PaodingAnalyzer(); String input = "我爱北京天安门!"; TokenStream ts = analyzer.tokenStream("", new StringReader(input)); Token token = new Token(); while(null != (token = ts.next(null))) System.out.println(token.term()); } }
大家通过这个例子可以看到,padoding分词器相当的强大,在此我们也不过多介绍,有兴趣的朋友可以看解压后的中文操作手册。