Lucene 实现简单的搜索

首先先讲解几个Lucene的基本属性和方法

属性:

totalHits ----匹配搜索条件的文档数量

scoreDocs[]----包含搜索结果的ScoreDoc对象数组

方法:

getMaxScore----如果已经完成排序(当通过与排序时,程序需要分别控制是否对该域进行评分计算)就返回最大的评分。

package lab02;

import java.io.File;
import java.io.IOException;

import org.apache.lucene.document.Document;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.TermQuery;
import org.apache.lucene.search.TopDocs;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory;

public class BasicSearchTest {

	/**
	 * @author Owater
	 * @param args
	 */
	public static void main(String[] args) throws IOException {
		// TODO Auto-generated method stub
		String indexDir = "E:/MyEclipse/Lucene/lab02/index" ;
		//打开指定目录下的索引
		Directory dir = FSDirectory.open(new File(indexDir));
		IndexReader reader = IndexReader.open(dir);
		//显示索引中的所有文档
		System.out.println("索引里面document列表:");
		for(int i=0;i<reader.numDocs();i++){
			System.out.println(reader.document(i));
		}
		//输出索引中文文档的数目
		System.out.println("索引里面document数量是:"+reader.numDocs());
		reader.close();
		
		IndexSearcher searcher = new IndexSearcher(dir);//构建IndexSearcher对象
		//构建Term对象,域名为"bookname",域值为"book3"
		Term t = new Term("bookname", "测试隐藏");
		Query query = new TermQuery(t);
		//按照指定的query查询,获得评分最高的10个文档
		TopDocs hits = searcher.search(query, 10);
		System.out.println("查询到的文档数是:"+hits.totalHits);
		Document document;
		for(int i = 0;i<hits.totalHits;i++){
			document=searcher.doc(hits.scoreDocs[i].doc);
			System.out.println("查询到的文档是:"+document);
			System.out.println("文档编号和评价分数是:"+hits.scoreDocs[i].toString());
		}
		System.out.println("文档最高评价分数是:"+hits.getMaxScore());

	}

}



你可能感兴趣的:(Lucene)