常用类简介
Directory 指定索引所在目录
FSDirectory 存放于磁盘上的文件系统
RAMDirectory 存放于内存中的目录,用于测试等用途
如Directory directory=FSDirectory.open(new File("filePath"));
IndexReader 读索引,依靠Directory类初始化
如 IndexReader reader=DirectoryReader.open(directory);
IndexSearcher 用于索引检索,依靠IndexReader类初始化。依靠Query类进行搜索。
如IndexSearcher searcher=new IndexSearcher(reader);
Analyzer 分词器
如Analyzer analyzer=new StandardAnalyzer();
Term 描述要查找单词所在的域(Field)与内容(content)。
如Term term=new Term("field","content");
Query 查询类,抽象类
TermQuery 最简单、最基本的Query,用来查询不切分的单词。依靠Term类初始化
如Query query=new TermQuery(term);
TopDocs 存放IndexSearcher类的查询结果
如TopDocs topDocs=searcher.search(query,10);
ScoreDoc ScoreDoc[]数组用来存放查询结果中的文档信息
如ScoreDoc[] scoreDocs = topdocs.scoreDocs;
ScoreDoc 中的score属性表示相关程度,取值范围[0,1],越大越相关。
概览:
Directory directory=FSDirectory.open(new File("filePath"));
IndexReader reader=DirectoryReader.open(directory);
IndexSearcher searcher=new IndexSearcher(reader);
Analyzer analyzer=new StandardAnalyzer();
Term term=new Term("field","content");
Query query=new TermQuery(term);
TopDocs topDocs=searcher.search(query, 10);
ScoreDoc[] hits=topDocs.scoreDocs;
for(ScoreDoc hit :hits){
System.out.println(hit.doc+hit.score);
}
索引的检索相关代码
原文:http://blog.csdn.net/chuchus/article/details/40923939