共计 1781 个字符,预计需要花费 5 分钟才能阅读完成。
这期内容当中丸趣 TV 小编将会给大家带来有关 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());
}
上述就是丸趣 TV 小编为大家分享的 Lucene 如何实现简单的搜索了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注丸趣 TV 行业资讯频道。
正文完