Lucene 实现简单的搜索
程序员文章站
2022-07-08 19:25:07
...
首先先讲解几个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());
}
}
转载于:https://my.oschina.net/Owater/blog/215262
上一篇: Spring MVC 数据校验
下一篇: JSP脚本简介