利用Lucene的IndexWriter创建索引(详解)java
须要lucene-analyzers-common-4.5.1.jar以上linux
/*
* 创建索引,而后把创建后的文档添加到索引中去
* 提示先使用Document和Field把Field加入到Document中去,
* 接着把Document创建成为一个索引
* */
package comThree;apache
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{oop
//建立索引的目录
private String INDEX_PATH = "E:\\Lucene项目\\索引目录";
Document bookdoc1 = null;
public BookIndex(){spa
bookdoc1 = new Document();
System.out.println("开始建立书的Field字段---------->>>>");htm
//书的编号
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