利用Lucene创建索引

2016/05/24 17:08
阅读数 90

利用Lucene的IndexWriter建立索引(详解)

需要lucene-analyzers-common-4.5.1.jar以上

/*
 * 建立索引,然后把建立后的文档添加到索引中去
 * 提示先使用Document和Field把Field加入到Document中去,
 * 接着把Document建立成为一个索引
 * */
package comThree;

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.IndexWriter;


public class BookIndex{


//创建索引的目录
private String INDEX_PATH = "E:\\Lucene项目\\索引目录";
Document  bookdoc1 = null;
public BookIndex(){

bookdoc1 = new Document();
System.out.println("开始创建书的Field字段---------->>>>");

//书的编号
Field bookNo = new Field("booknumber", "FB309663004", Field.Store.YES, Field.Index.TOKENIZED);
//书名
Field bookName = new Field("bookName", "钢铁是怎样炼成的", Field.Store.YES, Field.Index.TOKENIZED );

//书的作者
Field anthor = new Field("author", "匿名", Field.Store.YES, Field.Index.TOKENIZED);

//出版日期
Field publishdate = new Field("publishdate", "出版日期", Field.Store.YES, Field.Index.NO);

//描述
Field bookabstract = new Field("abstract", "钢铁是怎样炼成的", Field.Store.NO, Field.Index.TOKENIZED);


//价格
Field price = new Field("price", "25.00", Field.Store.YES, Field.Index.NO);

System.out.println("完成创建书的Field字段---------->>>>");

System.out.println("开始将书的字段放入到文档中-------------》》");
//把Field加入Document
bookdoc1.add(bookNo);
bookdoc1.add(bookName);
bookdoc1.add(bookabstract);
bookdoc1.add(publishdate);
bookdoc1.add(price);

System.out.println("完成书的字段放入到文档中------------->>>>>");

try{

System.out.println("开始创建索引-------------------->>>>");
//创建索引实例
IndexWriter writer = new IndexWriter(INDEX_PATH, new StandardAnalyzer());

//构建一个indexWriter的实例
writer.addDocument(bookdoc1);

//在这里必须要关闭,否则会出现异常,例如数据没有写入完整。
writer.close();
System.out.println("完成索引的创建并且存储完毕, 索引的存放位置在:" + INDEX_PATH);
}catch(IOException e){
e.printStackTrace();

}

    public static void main(String[] args){
    BookIndex BI = new BookIndex();
    }


}

--------------------------------------分割线 --------------------------------------

基于Lucene多索引进行索引和搜索 http://www.linuxidc.com/Linux/2012-05/59757.htm

Lucene 实战(第2版) 中文版 配套源代码 http://www.linuxidc.com/Linux/2013-10/91055.htm

Lucene 实战(第2版) PDF高清中文版 http://www.linuxidc.com/Linux/2013-10/91052.htm

使用Lucene-Spatial实现集成地理位置的全文检索 http://www.linuxidc.com/Linux/2012-02/53117.htm

Lucene + Hadoop 分布式搜索运行框架 Nut 1.0a9 http://www.linuxidc.com/Linux/2012-02/53113.htm

Lucene + Hadoop 分布式搜索运行框架 Nut 1.0a8 http://www.linuxidc.com/Linux/2012-02/53111.htm

Lucene + Hadoop 分布式搜索运行框架 Nut 1.0a7 http://www.linuxidc.com/Linux/2012-02/53110.htm

Project 2-1: 配置Lucene, 建立WEB查询系统[Ubuntu 10.10] http://www.linuxidc.com/Linux/2010-11/30103.htm

展开阅读全文
打赏
2
2 收藏
分享
加载中
更多评论
打赏
0 评论
2 收藏
2
分享
返回顶部
顶部