SortByMultiFields.java
上传用户:cctqzzy
上传日期:2022-03-14
资源大小:12198k
文件大小:5k
源码类别:

搜索引擎

开发平台:

Java

  1. package chapter7;
  2. import java.io.IOException;
  3. import org.apache.lucene.analysis.standard.StandardAnalyzer;
  4. import org.apache.lucene.document.Document;
  5. import org.apache.lucene.document.Field;
  6. import org.apache.lucene.index.IndexWriter;
  7. import org.apache.lucene.queryParser.ParseException;
  8. import org.apache.lucene.queryParser.QueryParser;
  9. import org.apache.lucene.search.Hits;
  10. import org.apache.lucene.search.IndexSearcher;
  11. import org.apache.lucene.search.Query;
  12. import org.apache.lucene.search.Sort;
  13. import org.apache.lucene.search.SortField;
  14. import org.apache.lucene.store.RAMDirectory;
  15. public class SortByMultiFields {
  16. static String[] ContentList = { "搜索 引擎","Lucene 使用 方便", "使用 Lucene","Lucene 功能 强大", "Lucene 开放 源码" , "Lucene 源码" };
  17. static String[] NumberList = { "No.0", "No.1", "No.2", "No.3", "No.4","No.2"};
  18. static String[] OrderList = { "0", "3", "2", "3","1","1"};
  19. public static void main(String[] args) throws IOException{
  20. searchIndex();
  21. }
  22. // 创建索引并通过Sort改变检索结果排序
  23. private static void searchIndex() throws IOException{   
  24. try{
  25. RAMDirectory ramdirectory = new RAMDirectory(); // 内存目录
  26. IndexWriter writer = new IndexWriter(ramdirectory,new StandardAnalyzer(),true);
  27. for (int i = 0; i < ContentList.length; i++)
  28.     {
  29.         Document document = new Document(); // 创建文档对象
  30.         // 创建域对象
  31.         Field fieldContent = new Field("Content", ContentList[i], Field.Store.YES, Field.Index.TOKENIZED);
  32.         Field fieldNumber  = new Field("Number" , NumberList[i] , Field.Store.YES, Field.Index.TOKENIZED);
  33.         Field fieldOrder   = new Field("Order"  , OrderList[i]  , Field.Store.YES, Field.Index.TOKENIZED);
  34.         document.add(fieldContent);         // 添加创建的文本域到当前文档
  35.         document.add(fieldNumber);         
  36.         document.add(fieldOrder);         
  37.         writer.addDocument(document);       // 完成的文档添加到索引
  38.     }
  39. writer.close();                         // 关闭索引
  40.     IndexSearcher searcher = new IndexSearcher(ramdirectory);               // 创建检索器
  41.     QueryParser parser = new QueryParser("Content",new StandardAnalyzer()); // 创建查询分析器
  42.     Query  query = parser.parse("Lucene");  // 生成查询对象
  43.     Hits rstDoc;
  44.     System.out.println("(a)Lucene默认相关性排序");
  45.     System.out.println("-----------------------------------");     
  46.     rstDoc = searcher.search(query);      // Lucene默认相关性排序
  47.     for (int i = 0; i < rstDoc.length(); i++)  // 遍历获取文档,并读取相关参数
  48.     {
  49.         Document doc = rstDoc.doc(i);
  50.         System.out.println( doc.get("Order")  + " " + doc.get("Number")  + " " + doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
  51.     }
  52.     
  53.     System.out.println("");
  54.     System.out.println("(b)Sort指定域Order文档排序");
  55.     System.out.println("-----------------------------------");     
  56.     rstDoc = searcher.search(query,new Sort("Order"));   // Sort静态常量INDEXORDER文档序排序
  57.     for (int i = 0; i < rstDoc.length(); i++)   // 遍历获取文档,并读取相关参数
  58.     {
  59.         Document doc = rstDoc.doc(i);
  60.         System.out.println( doc.get("Order")  + " " + doc.get("Number")  + " " + doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
  61.     }          
  62.     System.out.println("");
  63.     System.out.println("(c)Sort指定联合域Order,Number文档排序");
  64.     System.out.println("-----------------------------------");
  65.     SortField SortArray1[];
  66.     
  67.     SortArray1 = new SortField[]{new SortField("Order"),new SortField("Number")};
  68.     rstDoc = searcher.search(query,new Sort( SortArray1 ));  // Sort静态常量INDEXORDER文档序排序
  69.     for (int i = 0; i < rstDoc.length(); i++)   // 遍历获取文档,并读取相关参数
  70.     {
  71.         Document doc = rstDoc.doc(i);
  72.         System.out.println(doc.get("Order")  + " " + doc.get("Number")  + " " + doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
  73.     }
  74.     System.out.println("");
  75.     System.out.println("(d)Sort指定联合域Number,Order文档排序");
  76.     System.out.println("-----------------------------------");
  77.     SortField SortArray2[];
  78.     
  79.     SortArray2 = new SortField[]{new SortField("Number"),new SortField("Order")};
  80.     rstDoc = searcher.search(query,new Sort( SortArray2 ));  // Sort静态常量INDEXORDER文档序排序
  81.     for (int i = 0; i < rstDoc.length(); i++)      // 遍历获取文档,并读取相关参数
  82.     {
  83.         Document doc = rstDoc.doc(i);
  84.         System.out.println( doc.get("Number")  + " " + doc.get("Order")  + " " + doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
  85.     }
  86.     searcher.close();
  87. } catch(ParseException e){
  88. System.out.println("ParseException ");
  89. } catch(IOException e){
  90. System.out.println("IOException  ");
  91. }
  92. }
  93. }