lucene分词

1.Analyzer里面有个重要的方法,就是

public abstract TokenStream tokenStream(String fieldName, Reader reader);

一个TokenStream是用来走访Token的iterator(迭代器),TokenStream类里面保存分词后的所有Token,里面有个最重要的方法就是next();方法,返回下一个Token。

public abstract class TokenStream {

public abstract Token next() throws IOException;

public void close() throws IOException {}

}


一个Tokenizer,is-a TokenStream(派生自TokenStream),其输入为Reader


public abstract class Tokenizer extends TokenStream {

protected Reader input;

protected Tokenizer() {}

protected Tokenizer(Reader input) {

this.input = input;

}

public void close() throws IOException {

input.close();

}

}




一个TokenFilter is–a TokenStream(派生自TokenStream),其义如名就是用来完成对TokenStream的过滤操作,譬如去StopWords,将Token变为小写等。


public abstract class TokenFilter extends TokenStream {

protected TokenStream input;

protected TokenFilter() {}

protected TokenFilter(TokenStream input) {

this.input = input;

}

public void close() throws IOException {

input.close();

}

}



一个Analyzer就是一个TokenStream工厂


public abstract class Analyzer {

public TokenStream tokenStream(String fieldName, Reader reader)

{

return tokenStream(reader);

}

public TokenStream tokenStream(Reader reader)

{

return tokenStream(null, reader);

}

}



1.每个词条就是一个Token。Token类就是记录这些词条的原始信息的。
3.Tokenizer继承于TokenStream。
4.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值