?? sortdocid.java
字號(hào):
package chapter7;
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;
import org.apache.lucene.queryParser.ParseException;
import org.apache.lucene.queryParser.QueryParser;
import org.apache.lucene.search.Hits;
import org.apache.lucene.search.IndexSearcher;
import org.apache.lucene.search.Query;
import org.apache.lucene.search.Sort;
import org.apache.lucene.store.RAMDirectory;
public class SortDocID {
static String[] ContentList = { "Lucene 使用 方便", "使用 Lucene","Lucene 功能 強(qiáng)大", "Lucene 開(kāi)放 源碼" };
static String[] NumberList = { "No.1", "No.2", "No.3", "No.4"};
static String[] OrderList = { "3", "2", "3","1"};
public static void main(String[] args) throws IOException{
searchIndex();
}
// 創(chuàng)建索引并通過(guò)Sort改變檢索結(jié)果排序
private static void searchIndex() throws IOException{
try{
RAMDirectory ramdirectory = new RAMDirectory(); // 內(nèi)存目錄
IndexWriter writer = new IndexWriter(ramdirectory,new StandardAnalyzer(),true);
for (int i = 0; i < ContentList.length; i++)
{
Document document = new Document(); // 創(chuàng)建文檔對(duì)象
// 創(chuàng)建域?qū)ο? Field fieldContent = new Field("Content", ContentList[i], Field.Store.YES, Field.Index.TOKENIZED);
Field fieldNumber = new Field("Number" , NumberList[i] , Field.Store.YES, Field.Index.TOKENIZED);
Field fieldOrder = new Field("Order" , OrderList[i] , Field.Store.YES, Field.Index.TOKENIZED);
document.add(fieldContent); // 添加創(chuàng)建的文本域到當(dāng)前文檔
writer.addDocument(document); // 完成的文檔添加到索引
}
writer.close(); // 關(guān)閉索引
IndexSearcher searcher = new IndexSearcher(ramdirectory); // 創(chuàng)建檢索器
QueryParser parser = new QueryParser("Content",new StandardAnalyzer()); // 創(chuàng)建查詢(xún)分析器
Query query = parser.parse("Lucene"); // 生成查詢(xún)對(duì)象
Hits rstDoc;
System.out.println("Lucene默認(rèn)相關(guān)性排序");
System.out.println("-----------------------------------");
rstDoc = searcher.search(query); // Lucene默認(rèn)相關(guān)性排序
for (int i = 0; i < rstDoc.length(); i++) // 遍歷獲取文檔,并讀取相關(guān)參數(shù)
{
Document doc = rstDoc.doc(i);
System.out.println( doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
}
System.out.println("");
System.out.println("Sort靜態(tài)常量INDEXORDER文檔序排序");
System.out.println("-----------------------------------");
rstDoc = searcher.search(query,Sort.INDEXORDER); // Sort靜態(tài)常量INDEXORDER文檔序排序
for (int i = 0; i < rstDoc.length(); i++) // 遍歷獲取文檔,并讀取相關(guān)參數(shù)
{
Document doc = rstDoc.doc(i);
System.out.println( doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
}
searcher.close();
} catch(ParseException e){
System.out.println("ParseException ");
} catch(IOException e){
System.out.println("IOException ");
}
}
}
?? 快捷鍵說(shuō)明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -