1、在windows系统下的的C盘,建一个名叫s的文件夹,在该文件夹里面随便建三个txt文件,随便起名啦,就叫"1.txt","2.txt"和"3.txt"啦
其中1.txt的内容如下:
代码
而"2.txt"和"3.txt"的内容也可以随便写几写,这里懒写,就复制一个和1.txt文件的内容一样吧
2、下载lucene包,放在classpath路径中
建立索引:
代码
-
package lighter.iteye.com;
-
-
import java.io.BufferedReader;
-
import java.io.File;
-
import java.io.FileInputStream;
-
import java.io.IOException;
-
import java.io.InputStreamReader;
-
import java.util.Date;
-
-
import org.apache.lucene.analysis.Analyzer;
-
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;
-
-
-
-
-
public class TextFileIndexer {
-
public static void main(String[] args) throws Exception {
-
-
File fileDir = new File("c:\\s");
-
-
-
File indexDir = new File("c:\\index");
-
Analyzer luceneAnalyzer = new StandardAnalyzer();
-
IndexWriter indexWriter = new IndexWriter(indexDir, luceneAnalyzer,
-
true);
-
File[] textFiles = fileDir.listFiles();
-
long startTime = new Date().getTime();
-
-
-
for (int i = 0; i < textFiles.length; i++) {
-
if (textFiles[i].isFile()
-
&& textFiles[i].getName().endsWith(".txt")) {
-
System.out.println("File " + textFiles[i].getCanonicalPath()
-
+ "正在被索引....");
-
String temp = FileReaderAll(textFiles[i].getCanonicalPath(),
-
"GBK");
-
System.out.println(temp);
-
Document document = new Document();
-
Field FieldPath = new Field("path", textFiles[i].getPath(),
-
Field.Store.YES, Field.Index.NO);
-
Field FieldBody = new Field("body", temp, Field.Store.YES,
-
Field.Index.TOKENIZED,
-
Field.TermVector.WITH_POSITIONS_OFFSETS);
-
document.add(FieldPath);
-
document.add(FieldBody);
-
indexWriter.addDocument(document);
-
}
-
}
-
-
indexWriter.optimize();
-
indexWriter.close();
-
-
-
long endTime = new Date().getTime();
-
System.out
-
.println("这花费了"
-
+ (endTime - startTime)
-
+ " 毫秒来把文档增加到索引里面去!"
-
+ fileDir.getPath());
-
}
-
-
public static String FileReaderAll(String FileName, String charset)
-
throws IOException {
-
BufferedReader reader = new BufferedReader(new InputStreamReader(
-
new FileInputStream(FileName), charset));
-
String line = new String();
-
String temp = new String();
-
-
while ((line = reader.readLine()) != null) {
-
temp += line;
-
}
-
reader.close();
-
return temp;
-
}
-
}
索引的结果:
代码
-
File C:\s\1.txt正在被索引....
-
中华人民共和国全国人民2006年
-
File C:\s\2.txt正在被索引....
-
中华人民共和国全国人民2006年
-
File C:\s\3.txt正在被索引....
-
中华人民共和国全国人民2006年
-
这花费了297 毫秒来把文档增加到索引里面去!c:\s
3、建立了索引之后,查询啦....
代码
-
package lighter.iteye.com;
-
-
import java.io.IOException;
-
-
import org.apache.lucene.analysis.Analyzer;
-
import org.apache.lucene.analysis.standard.StandardAnalyzer;
-
import org.apache.lucene.queryParser.ParseException;
-
import org.apache.lucene.queryParser.QueryParser;
-
import org.apache.lucene.search.Hits;
-
import org.apache.lucene.search.IndexSearcher;
-
import org.apache.lucene.search.Query;
-
-
public class TestQuery {
-
public static void main(String[] args) throws IOException, ParseException {
-
Hits hits = null;
-
String queryString = "中华";
-
Query query = null;
-
IndexSearcher searcher = new IndexSearcher("c:\\index");
-
-
Analyzer analyzer = new StandardAnalyzer();
-
try {
-
QueryParser qp = new QueryParser("body", analyzer);
-
query = qp.parse(queryString);
-
} catch (ParseException e) {
-
}
-
if (searcher != null) {
-
hits = searcher.search(query);
-
if (hits.length() > 0) {
-
System.out.println("找到:" + hits.length() + " 个结果!");
-
}
-
}
-
}
-
-
}
其运行结果:
引用
找到:3 个结果!
Lucene 其实很简单的,它最主要就是做两件事:建立索引和进行搜索
来看一些在lucene中使用的术语,这里并不打算作详细的介绍,只是点一下而已----因为这一个世界有一种好东西,叫搜索。
IndexWriter:lucene中最重要的的类之一,它主要是用来将文档加入索引,同时控制索引过程中的一些参数使用。
Analyzer:分析器,主要用于分析搜索引擎遇到的各种文本。常用的有StandardAnalyzer分析器,StopAnalyzer分析器,WhitespaceAnalyzer分析器等。
Directory:索引存放的位置;lucene提供了两种索引存放的位置,一种是磁盘,一种是内存。一般情况将索引放在磁盘上;相应地lucene提供了FSDirectory和RAMDirectory两个类。
Document:文档;Document相当于一个要进行索引的单元,任何可以想要被索引的文件都必须转化为Document对象才能进行索引。
Field:字段。
IndexSearcher:是lucene中最基本的检索工具,所有的检索都会用到IndexSearcher工具;
Query:查询,lucene中支持模糊查询,语义查询,短语查询,组合查询等等,如有TermQuery,BooleanQuery,RangeQuery,WildcardQuery等一些类。
QueryParser: 是一个解析用户输入的工具,可以通过扫描用户输入的字符串,生成Query对象。
Hits:在搜索完成之后,需要把搜索结果返回并显示给用户,只有这样才算是完成搜索的目的。在lucene中,搜索的结果的集合是用Hits类的实例来表示的
分享到:
相关推荐
Lucene入门与使用,非常简单,适合入门
`lucene入门小实例.txt` 文件中可能包含了一个简单的Lucene使用示例,例如: 1. 创建 `Directory` 对象,比如使用 `FSDirectory.open()` 打开一个文件系统的目录来存储索引。 2. 实例化 `Analyzer`,如使用 `...
这个“lucene入门小例子”很可能是为了帮助初学者理解并掌握Lucene的基本用法而设计的一系列示例代码。 Lucene的核心概念包括索引、文档、字段和查询。首先,你需要理解索引的概念,它类似于传统数据库中的索引,但...
以上是Lucene入门的基本知识和关键概念,通过深入学习和实践,你可以掌握如何利用Lucene构建强大的全文搜索引擎。记住,实践中遇到的问题往往是最好的学习资源,不断尝试和解决,你将逐渐成为Lucene的专家。
**Lucene入门学习文档** **一、什么是Lucene** Lucene是Apache软件基金会下的一个开源全文检索库,它提供了一个高性能、可扩展的信息检索服务。Lucene最初由Doug Cutting开发,现在已经成为Java社区中事实上的标准...
【Lucene】Lucene入门心得 Lucene是一个高性能、全文本搜索库,由Apache软件基金会开发,被广泛应用于各种搜索引擎的构建。它提供了一个简单的API,使得开发者可以方便地在自己的应用程序中集成全文检索功能。...
**全文搜索引擎Lucene入门** 全文搜索引擎Lucene是Apache软件基金会的一个开放源代码项目,它为Java开发者提供了一个高性能、可扩展的信息检索库。Lucene以其强大的文本搜索功能和高效的索引能力,在各种需要全文...
《Lucene入门到项目开发》 Lucene是一个高性能、全文本搜索库,由Apache软件基金会开发,被广泛应用于各种搜索引擎的构建。它提供了一个简单但功能强大的API,可以帮助开发者快速实现对文本数据的检索和分析。 一...
### Lucene 入门基础教程知识点详解 #### 一、Lucene简介 - **定义**:Lucene是一款高性能、全功能的文本搜索引擎库,由Java编写而成,属于Apache项目的一部分。 - **适用场景**:适合于任何需要进行全文检索的应用...
在这个经典Lucene入门模块中,我们将深入理解如何使用Lucene进行索引创建和搜索操作。 首先,我们来看Lucene如何建立数据的索引。这通常涉及以下几个步骤: 1. **索引创建**:使用 `IndexWriter` 对象来创建或更新...
这个“Lucene入门demo”将帮助我们理解如何使用 Lucene 进行基本的索引和搜索操作。 **一、Lucene 的核心概念** 1. **索引(Indexing)**: 在 Lucene 中,索引是文档内容的预处理结果,类似于数据库中的索引。通过...
**Lucene 入门指南** Lucene 是一个高性能、全文本搜索库,由 Apache 软件基金会开发并维护。它是 Java 开发人员用来构建搜索引擎应用程序的基础工具。本指南将帮助初学者理解 Lucene 的核心概念,以及如何利用它来...
【Lucene 入门体会】 Lucene 是一个强大的全文检索工具包,主要由 Java 编写,它提供了索引和搜索功能,使得开发者能够轻松地为应用程序添加高级搜索能力。作为Apache Jakarta家族的一员,Lucene 开源且免费,被...
### Lucene入门指南 #### 一、Lucene简介 **Lucene** 是一款高性能的全文检索引擎工具包,由 **Apache 软件基金会** 的 **Jakarta 项目组** 开发并维护。作为一款完全开放源代码的工具,Lucene 提供了一系列的功能...
【Lucene入门知识详解】 Lucene是一个基于Java的全文索引引擎工具包,它并不是一个完整的全文搜索引擎,而是提供了一套构建搜索引擎的基础组件。Lucene的主要目标是方便开发者将其集成到各类应用程序中,以实现高效...