lucene实现 在某一范围进行搜索 RangeQuery
2007-03-20 17:28
369 查看
RangeQuery query = new RangeQuery(beginTime, endTime, false); 最后一个参数表示是否包含本身
书上的完整例子如下:
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.RangeQuery;
public class RangeQueryTest {
public static void main (String [] args) throws Exception {
Document doc1 = new Document();
doc1.add(Field.Text("time", "200001"));
doc1.add(Field.Keyword("title", "doc1"));
Document doc2 = new Document();
doc2.add(Field.Text("time", "200002"));
doc2.add(Field.Keyword("title", "doc2"));
Document doc3 = new Document();
doc3.add(Field.Text("time", "200003"));
doc3.add(Field.Keyword("title", "doc3"));
Document doc4 = new Document();
doc4.add(Field.Text("time", "200004"));
doc4.add(Field.Keyword("title", "doc4"));
Document doc5 = new Document();
doc5.add(Field.Text("time", "200005"));
doc5.add(Field.Keyword("title", "doc5"));
IndexWriter writer = new IndexWriter("c://index", new StandardAnalyzer(), true);
writer.setUseCompoundFile(true);
writer.addDocument(doc1);
writer.addDocument(doc2);
writer.addDocument(doc3);
writer.addDocument(doc4);
writer.addDocument(doc5);
writer.close();
IndexSearcher searcher = new IndexSearcher("c://index");
Term beginTime = new Term("time","200001");
Term endTime = new Term("time","200005");
Hits hits = null;
RangeQuery query = null;
query = new RangeQuery(beginTime, endTime, false);
hits = searcher.search(query);
printResult(hits, "从200001到200005的文档,不包括200001和200005");
query = new RangeQuery(beginTime, endTime, true);
hits = searcher.search(query);
printResult(hits, "从200001到200005的文档,包括200001和200005");
}
public static void printResult(Hits hits, String key) throws Exception {
System.out.println("查找 /"" + key + "/" :");
if (hits != null) {
if (hits.length() == 0) {
System.out.println("没有找到任何结果");
} else {
System.out.print("找到");
for (int i = 0; i < hits.length(); i++) {
Document d = hits.doc(i);
String dname = d.get("title");
System.out.print(dname + " " );
}
System.out.println();
System.out.println();
}
}
}
}
书上的完整例子如下:
import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.index.Term;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.RangeQuery;
public class RangeQueryTest {
public static void main (String [] args) throws Exception {
Document doc1 = new Document();
doc1.add(Field.Text("time", "200001"));
doc1.add(Field.Keyword("title", "doc1"));
Document doc2 = new Document();
doc2.add(Field.Text("time", "200002"));
doc2.add(Field.Keyword("title", "doc2"));
Document doc3 = new Document();
doc3.add(Field.Text("time", "200003"));
doc3.add(Field.Keyword("title", "doc3"));
Document doc4 = new Document();
doc4.add(Field.Text("time", "200004"));
doc4.add(Field.Keyword("title", "doc4"));
Document doc5 = new Document();
doc5.add(Field.Text("time", "200005"));
doc5.add(Field.Keyword("title", "doc5"));
IndexWriter writer = new IndexWriter("c://index", new StandardAnalyzer(), true);
writer.setUseCompoundFile(true);
writer.addDocument(doc1);
writer.addDocument(doc2);
writer.addDocument(doc3);
writer.addDocument(doc4);
writer.addDocument(doc5);
writer.close();
IndexSearcher searcher = new IndexSearcher("c://index");
Term beginTime = new Term("time","200001");
Term endTime = new Term("time","200005");
Hits hits = null;
RangeQuery query = null;
query = new RangeQuery(beginTime, endTime, false);
hits = searcher.search(query);
printResult(hits, "从200001到200005的文档,不包括200001和200005");
query = new RangeQuery(beginTime, endTime, true);
hits = searcher.search(query);
printResult(hits, "从200001到200005的文档,包括200001和200005");
}
public static void printResult(Hits hits, String key) throws Exception {
System.out.println("查找 /"" + key + "/" :");
if (hits != null) {
if (hits.length() == 0) {
System.out.println("没有找到任何结果");
} else {
System.out.print("找到");
for (int i = 0; i < hits.length(); i++) {
Document d = hits.doc(i);
String dname = d.get("title");
System.out.print(dname + " " );
}
System.out.println();
System.out.println();
}
}
}
}
相关文章推荐
- lucene-查询query->RangeQuery在某一范围内搜索
- lucene-RangeQuery范围内搜索
- Lucene范围搜索的6种实现方式
- 如何在Lucene里面进行数字范围搜索 (Numeric Range Query)
- Lucene实现多种高级搜索形式
- Lucene下引入ICTCLAS进行中文分词的实现方法
- Lucene5.5.4入门以及基于Lucene实现博客搜索功能
- WebGIS中解决使用Lucene进行兴趣点搜索排序的两种思路
- 5.极小极大化搜索与α-β剪枝:编程实现人机“三子棋”小游戏并对算法过程进行动态展示
- 利用Lucene.net搜索引擎进行多条件搜索的做法
- lucene.net 3.0.3、结合盘古分词进行搜索的小例子(分页功能)
- Lucene.Net:使用eaglet的盘古分词进行分词和搜索
- 成功将99收藏夹实现基于Lucene的站内全文搜索
- lucene (2.9--- 3.6) 范围搜索优化
- solr实现满足指定距离范围条件的搜索
- 使用Lucene.NET实现简单的站内搜索
- Java实现lucene搜索功能的方法(推荐)
- lucene 多索引目录搜索实现方法
- Lucene小练九——各种搜索(精确,范围,数字)
- 利用Lucene.net搜索引擎进行多条件搜索的做法