lucene入门系列(二、建立索引)

文档已经处理完毕,接下来,开始好似用Lucene处理相关内容。通常情况下,使用 Lucene的步骤如下所示:
(1)为要处理的内容建立索引
(2)构建查询对象
(3)在索引中查找
package com.heming.lucene.process;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;

import jeasy.analysis.MMAnalyzer;

import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;

/**
* 为文档创建索引
*
* @author 何明
*
*/
public class IndexProcesser {

// 成员变量,存储创建的索引文件存放的位置
private String INDEX_STORE_PATH = "d:\\index";

// 创建索引
public void createIndex(String inputDir) {

try {

// 以MMAnalyzer作为分词工具创建一个IndexWriter
IndexWriter writer = new IndexWriter(INDEX_STORE_PATH,
new MMAnalyzer(), true);

File filesDir = new File(inputDir);

// 取得所有需要建立索引的文件数组
File[] files = filesDir.listFiles();

// 遍历数组
for (int i = 0; i < files.length; ++i) {

// 获取文件名
String fileName = files[i].getName();

// 判断文件是否为txt类型的文件
if (".txt"
.equals(fileName.substring(fileName.lastIndexOf(".")))) {

// 创建一个新的 Document
Document doc = new Document();

// 为文件名创建一个Field
Field field = new Field("filename", files[i].getName(),
Field.Store.YES, Field.Index.NOT_ANALYZED);

doc.add(field);

// 为文件内容创建一个Filed
field = new Field("content", loadFileToString(files[i]),
Field.Store.NO, Field.Index.NOT_ANALYZED);

doc.add(field);

// 把Document加入IndexWriter
writer.addDocument(doc);

}

}

// 关闭IndexWriter
writer.close();

} catch (Exception e) {

e.printStackTrace();

}

}

/**
* 从文件中把内容读出,所有的内容放在一个String 容器
*
* @param file
* @return
*/
private String loadFileToString(File file) {

try {

BufferedReader br = new BufferedReader(new FileReader(file));

StringBuffer sb = new StringBuffer();

String line = br.readLine();

while (null != line) {

sb.append(line);

line = br.readLine();

}

br.close();

return sb.toString();

} catch (Exception e) {

e.printStackTrace();

}

return null;
}

public static void main(String[] args) {

IndexProcesser processor = new IndexProcesser();

processor.createIndex("d:\\test");

}

}


我这里用的lucene版本是2.4的,分词用的MMAnalyzer
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值