博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
lucene的中文分词器http://www.blogjava.net/dreamstone/archive/2007/06/22/125726.html
阅读量:2399 次
发布时间:2019-05-10

本文共 3327 字,大约阅读时间需要 11 分钟。

 lucene的中文分词器到现在还没有好的解决办法。下边介绍了两个lucene自己提供的分词器和一个javaeye上的网友实现的分词器。关于各个分词器的不同见代码中的print信息。直接运行得到console的输出结果更容易对比不同。
package
 analyzer;
import
 java.io.Reader;
import
 java.io.StringReader;
import
 org.apache.lucene.analysis.Analyzer;
import
 org.apache.lucene.analysis.StopFilter;
import
 org.apache.lucene.analysis.Token;
import
 org.apache.lucene.analysis.TokenFilter;
import
 org.apache.lucene.analysis.TokenStream;
import
 org.apache.lucene.analysis.cjk.CJKAnalyzer;
import
 org.apache.lucene.analysis.cn.ChineseAnalyzer;
import
 org.apache.lucene.analysis.standard.StandardAnalyzer;
import
 org.mira.lucene.analysis.IK_CAnalyzer;
import
 org.mira.lucene.analysis.MIK_CAnalyzer;
import
 com.sohospace.lucene.analysis.xanalyzer.XAnalyzer;
import
 com.sohospace.lucene.analysis.xanalyzer.XFactory;
import
 com.sohospace.lucene.analysis.xanalyzer.XTokenizer;
//
中文分词使用了Paoding的分词技术,特表示感谢
public
 
class
 TestCJKAnalyzer 
{
    
private static String testString1 = "中华人民共和国在1949年建立,从此开始了新中国的伟大篇章";
    
private static String testString2 = "比尔盖茨从事餐饮业和服务业方面的工作";
    
public static void testStandard(String testString) throws Exception{
        Analyzer analyzer 
= new StandardAnalyzer();      
        Reader r 
= new StringReader(testString);      
        StopFilter sf 
= (StopFilter) analyzer.tokenStream("", r);
        System.err.println(
"=====standard analyzer====");
        System.err.println(
"分析方法:默认没有词只有字");
        Token t;      
        
while ((t = sf.next()) != null{      
            System.out.println(t.termText());      
        }
     
    }
    
public static void testCJK(String testString) throws Exception{
        Analyzer analyzer 
= new CJKAnalyzer();      
        Reader r 
= new StringReader(testString);      
        StopFilter sf 
= (StopFilter) analyzer.tokenStream("", r);
        System.err.println(
"=====cjk analyzer====");
        System.err.println(
"分析方法:交叉双字分割");
        Token t;      
        
while ((t = sf.next()) != null{      
            System.out.println(t.termText());      
        }
     
    }
    
public static void testChiniese(String testString) throws Exception{
        Analyzer analyzer 
= new ChineseAnalyzer();      
        Reader r 
= new StringReader(testString);      
        TokenFilter tf 
= (TokenFilter) analyzer.tokenStream("", r);
        System.err.println(
"=====chinese analyzer====");
        System.err.println(
"分析方法:基本等同StandardAnalyzer");
        Token t;      
        
while ((t = tf.next()) != null{      
            System.out.println(t.termText());      
        }
     
    }
    
public static void testPaoding(String testString) throws Exception{
        XAnalyzer analyzer 
= XFactory.getQueryAnalyzer();   
        Reader r 
= new StringReader(testString);   
        XTokenizer ts 
= (XTokenizer) analyzer.tokenStream("", r);   
        System.err.println(
"=====paoding analyzer====");
        System.err.println(
"分析方法:字典分词,去掉停止词。在字典不能匹配的情况下使用CJKAnalyzer的分割发。");
        Token t;   
        
while ((t = ts.next()) != null{   
           System.out.println(t.termText());   
        }
   
    }
    
public static void testJe(String testString) throws Exception{
//        Analyzer analyzer = new MIK_CAnalyzer();
        Analyzer analyzer = new IK_CAnalyzer();
        Reader r 
= new StringReader(testString); 
        TokenStream ts 
= (TokenStream)analyzer.tokenStream("", r);
        System.err.println(
"=====je analyzer====");
        System.err.println(
"分析方法:字典分词,正反双向搜索,具体不明");
        Token t;   
        
while ((t = ts.next()) != null{   
           System.out.println(t.termText());   
        }
   
    }
    
public static void main(String[] args) throws Exception{
//        String testString = testString1;
        String testString = testString1;
        System.out.println(testString);
        
        testStandard(testString);
        testCJK(testString);
        testPaoding(testString);
        
//        testChiniese(testString);
//        testJe(testString);
    }
}

posted on 2007-06-22 09:15 阅读(1157)     所属分类:

 

转载地址:http://pgjob.baihongyu.com/

你可能感兴趣的文章
《云计算架构技术与实践》序言(李德毅院士)
查看>>
SANS FOR572 Logstash
查看>>
OpenGL坐标系
查看>>
VS2008快捷键大全
查看>>
阿里开源限流组件 Sentinel 集群流控全解析
查看>>
Python的闭包和装饰器
查看>>
Virtual的一些总结
查看>>
java中File类创建和删除功能
查看>>
linux下常用网络操作(重点)
查看>>
职场中神奇的程序员,却常常被人说“太直”,这是什么样的思维?
查看>>
内存储器管理概述、内存分配与释放、地址映射机制(mm_struct, vm_area_struct)、malloc/free 的实现
查看>>
glibc-printf
查看>>
Listener--ServletContextListener接口的使用详解
查看>>
Listener--HttpSessionListener、ServletRequestListener接口的使用详解
查看>>
Struts2--非表单标签
查看>>
Oracle--同义词详解
查看>>
Oracle--存储过程概述、创建和执行
查看>>
Oracle--带参数的存储过程(IN、OUT和IN OUT)
查看>>
Oracle--触发器详解(分类、作用、执行顺序和语法)
查看>>
Oracle--DML触发器
查看>>