package ch2.lucenedemo.process;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import javax.swing.filechooser.FileFilter;
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 = "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 (fileName.substring(fileName.lastIndexOf("."))
.equals(".txt")) {
// 建立一個新的Document
Document doc = new Document();
// 為檔案名建立一個Field
Field field = new Field("filename", files[i].getName(),
Field.Store.YES, Field.Index.TOKENIZED);
doc.add(field);
// 為檔案內容建立一個Filed
field = new Field("content", loadFileToString(files[i]),
Field.Store.NO, Field.Index.TOKENIZED);
doc.add(field);
// 把Document加入IndexWriter
writer.addDocument(doc);
}
}
// 關閉IndexWriter
writer.close();
} catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args) {
IndexProcesser processor = new IndexProcesser();
processor.createIndex("d:\\testfolder");
}
public String loadFileToString(File file) {
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;
}
}
}
麻煩各位大大幫忙小弟如何解決與並還要安裝什麼語言才可測試..
此外eclipse測試下列三種都會有bug:
import org.apache.lucene.document.Document;
import org.apache.lucene.document.Field;
import org.apache.lucene.index.IndexWriter;
不知eclipse還要安裝什麼檔案才可執行