`
wjboy49
  • 浏览: 284631 次
  • 性别: Icon_minigender_1
  • 来自: 湖南岳阳
社区版块
存档分类
最新评论

Lucene-2.3.1 源代码阅读学习(2)

阅读更多

IndexWriter是一个非常重要的工具。建立索引必须从它开始。而且,从它的构造函数开始。

Document和Field是Lucene中两个最重要的概念。在建立索引的时候,也就是实例化一个索引器IndexWriter的之前,必须通过已经建立好的Document逻辑文件,将Document的对象添加到IndexWriter实例中,才能算是建立索引。

Document汇集数据源,这个数据源是通过Field来构造的。构造好Field之后,将每个Field对象加入到Document之中,可以通过Document来管理Field,然后将聚集的Document加入到IndexWriter中,建立索引,写入指定的Directory,为检索做准备。

写一个建立索引,然后读取索引的例子,代码如下:

package org.shirdrn.lucene;

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

import org.apache.lucene.analysis.standard.StandardAnalyzer;
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.CorruptIndexException;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexWriter;
import org.apache.lucene.store.LockObtainFailedException;

public class MyIndexWriter {
public static void main(String[] args){
   File myFile = new File("E:\\Lucene\\myindex");
   try {
    Document myDoc = new Document();
    Field myFieldNo = new Field("myNo","SN-BH-19830119",Field.Store.YES,Field.Index.UN_TOKENIZED);
    Field myFieldName = new Field("myName","家园使者",Field.Store.YES,Field.Index.UN_TOKENIZED);
    Field myFieldGender = new Field("myGender","男",Field.Store.YES,Field.Index.UN_TOKENIZED);
    Field myFieldDescb = new Field("myDescb","家园族长",Field.Store.YES,Field.Index.UN_TOKENIZED);
    myDoc.add(myFieldNo);
    myDoc.add(myFieldName);
    myDoc.add(myFieldGender);
    myDoc.add(myFieldDescb);
    Field hisFieldNo = new Field("hisNo","SN-BH-19860101",Field.Store.YES,Field.Index.UN_TOKENIZED);
    Field hisFieldName = new Field("hisName","爱刮的风",Field.Store.YES,Field.Index.UN_TOKENIZED);
    Field hisFieldGender = new Field("hisGender","女",Field.Store.YES,Field.Index.UN_TOKENIZED);
    Field hisFieldDescb = new Field("hisDescb","风尘族长",Field.Store.YES,Field.Index.UN_TOKENIZED);
    myDoc.add(hisFieldNo);
    myDoc.add(hisFieldName);
    myDoc.add(hisFieldGender);
    myDoc.add(hisFieldDescb);
    IndexWriter myWriter = new IndexWriter(myFile,new StandardAnalyzer(),true);    //   构造一个索引器,true指定了:向已经存在的索引中追加索引
    myWriter.addDocument(myDoc);
    myWriter.close();    // 关闭索引器,将追加的索引文件写入到索引目录中
    IndexReader myReader = IndexReader.open(myFile);    // 读取索引
    for(int i=0;i<myReader.numDocs();i++){
     System.out.println(myReader.document(i));    //   输出索引文件的信息
    }
   } catch (CorruptIndexException e) {
    e.printStackTrace();
   } catch (LockObtainFailedException e) {
    e.printStackTrace();
   } catch (IOException e) {
    e.printStackTrace();
   }
}

}

这里,使用File myFile = new File("E:\\Lucene\\myindex");作为一个参数来构造一个索引器。

运行程序,可以在目录E:\Lucene\myindex下看到生成的索引文件,一共有三个文件:

_0.cfs

segments.gen

segments_3

第一个是.cfs格式的,成为复合索引格式;第三个segments_3是一个索引段。

因为上面程序中使用了IndexReader,先打开索引文件,然后通过IndexReader的document()来读取索引文件的内容。

Field是由Document来管理维护的,上面的那个构造方法,第一个参数是Field的名称,如果没有这样一个标识,Document怎么找到它从而对它维护呢。

第二个参数是该Field的内容(一般来说是文本),可能在建立索引的时候对其处理,比如分词就是很重要的一项(是否分词要看第三、四个参数如何设置)。

后面的参数数关于该Field是否存储,以及是否分词。

现在只是将Field添加到Document中进行预处理,离建立索引还很远。真正建立索引是从一个Document添加到IndexWriter中开始的,即在此基础上IndexWriter初始化,这时,便调用了它的init方法,在init方法中调用了DocumentWiter类的addDocument()方法,才开始建立索引了。

Lucene建立索引的过程是相当复杂的,它要把已经添加到Document中的Field在内存中调出来,通过FieldInfos来实现进一步的处理。

 

分享到:
评论

相关推荐

    Lucene-2.3.1 源代码阅读学习

    《Lucene-2.3.1 源代码阅读学习》 Lucene是Apache软件基金会的一个开放源码项目,它是一个高性能、全文本搜索库,为开发者提供了在Java应用程序中实现全文检索功能的基础架构。本篇文章将深入探讨Lucene 2.3.1版本...

    lucene2.3.1

    总而言之,Lucene 2.3.1作为一款经典的搜索引擎框架,它的源代码不仅提供了学习信息检索理论的机会,也是实践和掌握Java编程、数据结构和算法的宝贵资源。通过对压缩包中的文件进行分析,开发者可以深入了解Lucene的...

    Lucene.Net2.3源码,最新版

    通过深入学习和理解这些源代码文件,开发者可以更好地掌握 Lucene.Net 的核心功能,如索引构建、查询解析、搜索排序、分词和性能优化。这有助于在实际项目中实现高效、精确的全文搜索引擎。同时,研究源码也能提升对...

    Baioogle-SearchEngine(百歌搜索引擎)

    4.其中src文件夹内为全部源代码,WebRoot为web应用部署文件 5.本系统的最小有效组件集合为:(约定:以下“*.*”均表示目录下的所有单独文件,不包括文件夹,而“/s”则表示所有的文件夹及其内部内容) src\*.* /s ...

    一个专业搜索公司关于lucene+solar资料(1)

    ### Lucene+Solor知识点概述 #### 一、搜索引擎基础理论 **1.1 Google神话** - **起源与发展:** - Google成立于1998年,由Larry Page和Sergey Brin创立。 - 初期以PageRank算法为核心,有效解决了当时互联网...

    JeeSite开发说明文档

    - **开源协议**:使用Apache License 2.0协议,源代码完全开源,没有商业限制。 - **技术栈成熟**:使用当前最主流的J2EE开发框架和技术,易于学习和维护。 - **数据库支持广泛**:支持多种数据库,如MySQL、Oracle...

    solr教材-PDF版

    - **1.4.1 目录结构说明**:Solr项目的目录结构清晰,主要包括src/main/java下的源代码、src/main/resources下的资源文件等。 - **1.4.2 Solrhome说明**:Solrhome是Solr实例的工作目录,包含了索引数据、配置文件等...

    Solr3.5开发应用指导

    - **1.4.1 目录结构说明**:Solr的核心源码主要由几个关键部分组成,如`src/main/java`包含Java源代码,`src/main/resources`存放配置文件等。 - **1.4.2 Solrhome说明**:Solrhome是Solr运行时使用的根目录,包含了...

    lifery6.1+cas初始化环境搭建及门户解决方案

    CAS (Central Authentication Service) 是一种开放源代码的单点登录协议和服务实现,主要用于Web应用的安全身份验证。CAS支持跨域的身份验证管理,允许用户通过一个中心服务进行一次登录即可访问多个应用系统。 **...

    ZendFramework中文文档

    2.3.1. 保存 ACL 数据确保持久性 2.3.2. 使用声明(Assert)来编写条件性的 ACL 规则 3. Zend_Auth 3.1. 简介 3.1.1. 适配器 3.1.2. 结果 3.1.3. 身份的持久(Persistence) 3.1.3.1. 在PHP Session 中的缺省...

Global site tag (gtag.js) - Google Analytics