这是我写的第二个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\\");
}
}