利用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
来源:oschina
链接:https://my.oschina.net/u/2671514/blog/680580