这期内容当中小编将会给大家带来有关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如何实现简单的搜索了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。