lucene 查询索引

继上篇创建索引之后,搜索索引


package com.cjr.lucene;

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

import org.apache.lucene.analysis.Analyzer;
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.index.DirectoryReader;
import org.apache.lucene.queryparser.classic.ParseException;
import org.apache.lucene.queryparser.classic.QueryParser;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.ScoreDoc;
import org.apache.lucene.search.TopDocs;
import org.apache.lucene.store.Directory;
import org.apache.lucene.store.FSDirectory;

/**
 * 搜索索引
 * lucene 4.10.2
 * @author chenjiarong
 *	
 */
public class Searcher {

	// 索引目录
	private static String indexDir = "F:\\工作区\\test";

	// 查询关键字
	private static String str = "假如你在森林里面迷了路,突然在你面前出现两条大路,你会如何做出选择";

	public static void main(String[] args) {
		Searcher searcher = new Searcher();
		searcher.search(indexDir, str);
	}

	/**
	 * 查询
	 * @param indexDir
	 * @param str
	 */
	public void search(String indexDir, String str) {
		Directory directory = null;
		try {
			// 分词器
			Analyzer analyzer = new StandardAnalyzer();
			
			// 打开索引文件
			directory = FSDirectory.open(new File(indexDir));

			DirectoryReader directoryReader = DirectoryReader.open(directory);
			
			IndexSearcher is = new IndexSearcher(directoryReader);

			//解析查询字符串
			QueryParser queryParser = new QueryParser("contents", analyzer);

			Query query = queryParser.parse(str);

			//搜索相似度最高的1条记录,以topdocs形式返回结果集
			TopDocs topDocs = is.search(query, 1);

			ScoreDoc[] scoreDocs = topDocs.scoreDocs;
			
			for (int i = 0; i < scoreDocs.length; i++) {
				// 加载匹配结果集
				Document targetDoc = is.doc(scoreDocs[i].doc);
				// 显示出来
				System.out.println("内容:" + targetDoc.toString());
			}

		} catch (IOException e) {
			e.printStackTrace();
		} catch (ParseException e) {
			e.printStackTrace();
		}finally{
			try {
				directory.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}

	}

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值