其实,lucene是一个很容易上手的搜索引擎框架,传统的搜索引擎,涉及到爬虫,也就是爬取网页,然后对网页进行加工,也就是索引,最后用于搜索,lucene这个框架可以很方便的帮你做到后面两个步骤,也就是索引和搜索!本文尝试通过一个例子,使大家掌握lucene的使用核心方法,包括分词、索引、搜索不同的目录、搜索不同的域,希望大家通过这个实例,对lucene和搜索引擎能有比较全面的认识!
package cn.soft;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.queryParser.MultiFieldQueryParser;
import org.apache.lucene.search.BooleanClause;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.MultiSearcher;
import org.apache.lucene.search.Query;
/**
* 这个实例包含了lucene所有的核心用法
* @author 李亮
*
*/
public class LuneceTest {
public LuneceTest(){
}
/**
* @param args
*/
public static void main(String[] args) {
try{
LuneceTest test = new LuneceTest();
test.index();
test.search("一");
}catch(Exception e){
e.printStackTrace();
}
System.out.println("OK");
}
/**
* 创建索引
*/
public void index() throws Exception{
/**
* 创建索引初始化,执行这些语句将创建或清空d:\\save\\目录下所有索引
*/
IndexWriter writeOne = new IndexWriter("d:\\save\\",new StandardAnalyzer(),true);
writeOne.close();
/**
* 往创建的初始化索引中添加内容,StandarAnalyzer表明用lunece自带的标准分词机制。
* false标示不覆盖原来该目录的索引
*/
IndexWriter writeTwo = new IndexWriter("d:\\save\\",new StandardAnalyzer(),false);
/* 创建一份文件 */
Document docOne = new Document();
/**
* 创建一个域 ArticleTitle,并往这个域里边添加内容,"Field.Store.YES" 表示该域里面的内容将被存储到索引
* Field.Index.TOKENIZED表示该域里的内容将被索引,以便用来搜索
*/
Field fieldOne = new Field("ActicleTitle","北京2008奥运会",Field.Store.YES,Field.Index.TOKENIZED);
docOne.add(fieldOne);
/* 创建另外一个域ActicleTitle,并往这个域里添加内容 */
Field fieldTwo = new Field("ActicleText","这是一届创造奇迹、超越梦想的奥运会....",Field.Store.YES,Field.Index.TOKENIZED);
docOne.add(fieldTwo);
/* 添加这份文件到索引 */
writeTwo.addDocument(docOne);
/* 同理,创建第二份文件 */
Document docTwo = new Document();
fieldOne = new Field("ActicleTitle","奥运会中国获得全球赞誉",Field.Store.YES,Field.Index.TOKENIZED);
docTwo.add(fieldOne);
fieldTwo = new Field("ActicleText","中国所获取的金牌总数排行榜的榜首第一位...",Field.Store.YES,Field.Index.TOKENIZED);
docTwo.add(fieldTwo);
writeTwo.addDocument(docTwo);
writeTwo.close();
}
public void search(String searchString) throws Exception{
/* 创建一个搜索,搜索刚才创建的d:\\save\\目录下的索引 */
IndexSearcher indexSearcher = new IndexSearcher("d:\\save\\");
/* 在这里我们只需要搜索一个目录 */
IndexSearcher indexSearchers[] = {indexSearcher};
/* 我们需要搜索两个域 "ActicleTitle" , "ActicleText"里面的内容 */
String[] fields = {"ActicleTitle","ActicleText"};
/* 下面这个表示要同时搜索这两个域,而且只要一个域里面有满足我们搜索的内容就行 */
BooleanClause.Occur[] clauses = {BooleanClause.Occur.SHOULD,BooleanClause.Occur.SHOULD};
/**
* MultiFieldQueryParser表示多个域解析
* 同时可以解析含空格的字符串,如果我们搜索"中国 金牌",根据前面的索引,显然搜到的是第二份文件
*/
Query query = MultiFieldQueryParser.parse(searchString,fields,clauses,new StandardAnalyzer());
/* MultiSearcher表示多目录搜索,在这里我们只有一个目录 */
MultiSearcher searcher = new MultiSearcher(indexSearchers);
/* 开始搜索 */
Hits h = searcher.search(query);
/* 把所搜出来的所有文件打印出来 */
for(int i=0;i<h.length();i++){
/* 打印出文件里面ArticleTitle域里面的内容 */
System.out.println(h.doc(i).get("ActicleTitle"));
/* 打印出文件里面ActicleText域里面的内容 */
System.out.println(h.doc(i).get("ActicleText"));
}
searcher.close();
}
}
wiss文档协同系统三分钟解决一切文档管理的烦恼,帮您完成公司文档到资产的转变!!!
更多功能欢迎访问
http://www.chinawiss.com