创建处理文档索的引类:IndexProcessor

131 篇文章 2 订阅

这是我写的第二个Lucene的代码,

这段代码的意思是创建一个索引,可以进行把文本进行处理,建立索引。

/基本的步骤是
//1.为要处理的内容建立索引
//2.构建查询对象
//3.在索引中查询

package ch2.lucenedemo.process;



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


import jeasy.analysis.MMAnalyzer;


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


/


public class IndexProcesser {
//成员变量, 存储创建的索引文件存放的位置
private String INDEX_STORE_PATH = "E:\\Lucene项目\\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(fileName.substring(fileName.lastIndexOf(".")).equals(".txt")){

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

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

doc.add(field);

//为文件内容创建一个filed
field = new Field("contant", loadFileToString(files[i]), Field.Store.NO, Field.Index.TOKENIZED);
doc.add(field);

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

}
}
writer.close();

}catch(Exception e){
e.printStackTrace();
}

}

//从文件中把内容读出, 所有的内容放在一个String中返回
private String loadFileToString(File file) {
// TODO 自动生成的方法存根
try{
BufferedReader br = new BufferedReader(new FileReader(file));
StringBuffer sb = new StringBuffer();
String line = br.readLine();
while(line != null){
sb.append(line);
line = br.readLine();
}
br.close();
return sb.toString();

}catch(IOException e){
e.printStackTrace();
return null;
}

}
public static void main(String[] args){
IndexProcesser processor = new IndexProcesser();
processor.createIndex("E:\\Lucene项目\\testfolder\\");
}

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨鑫newlfe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值