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

搜索引擎

开发平台:

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.store.RAMDirectory;
  14. public class SortRelavence {
  15. static String[] ContentList = { "Lucene 使用 方便", "使用 Lucene","Lucene 功能 强大", "Lucene 开放 源码" };
  16. public static void main(String[] args) throws IOException{
  17. searchIndex();
  18. }
  19. // 创建索引并通过Sort改变检索结果排序
  20. private static void searchIndex() throws IOException{   
  21. try{
  22. RAMDirectory ramdirectory = new RAMDirectory(); // 内存目录
  23. IndexWriter writer = new IndexWriter(ramdirectory,new StandardAnalyzer(),true);
  24. for (int i = 0; i < ContentList.length; i++)
  25.     {
  26.         Document document = new Document(); // 创建文档对象
  27.         // 创建域对象
  28.         Field fieldContent = new Field("Content", ContentList[i], Field.Store.YES, Field.Index.TOKENIZED);
  29.         document.add(fieldContent);         // 添加创建的文本域到当前文档
  30.         writer.addDocument(document);       // 完成的文档添加到索引
  31.     }
  32. writer.close();                         // 关闭索引
  33.     IndexSearcher searcher = new IndexSearcher(ramdirectory);               // 创建检索器
  34.     QueryParser parser = new QueryParser("Content",new StandardAnalyzer()); // 创建查询分析器
  35.     Query  query = parser.parse("Lucene");    // 生成查询对象
  36.     Hits rstDoc;
  37.     System.out.println("Lucene默认相关性排序");
  38.     System.out.println("-----------------------------------");     
  39.     rstDoc = searcher.search(query);      // Lucene默认相关性排序
  40.     for (int i = 0; i < rstDoc.length(); i++)  // 遍历获取文档,并读取相关参数
  41.     {
  42.         Document doc = rstDoc.doc(i);
  43.         System.out.println(doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
  44.     }
  45.     System.out.println("");
  46.     System.out.println("Sort静态常量实现相关性排序");
  47.     System.out.println("-----------------------------------");     
  48.     rstDoc = searcher.search(query,Sort.RELEVANCE);     // Sort静态常量实现相关性排序
  49.     for (int i = 0; i < rstDoc.length(); i++)  // 遍历获取文档,并读取相关参数
  50.     {
  51.         Document doc = rstDoc.doc(i);
  52.         System.out.println( doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
  53.     }
  54.     System.out.println("");     
  55.     System.out.println("Sort默认构造函数实现相关性排序");
  56.     System.out.println("-----------------------------------");     
  57.     rstDoc = searcher.search(query,new Sort());      // Sort默认构造函数实现相关性排序
  58.     for (int i = 0; i < rstDoc.length(); i++)  // 遍历获取文档,并读取相关参数
  59.     {
  60.         Document doc = rstDoc.doc(i);
  61.         System.out.println( doc.get("Content") + " Boost: " + doc.getBoost() + ", score : " + rstDoc.score(i));
  62.     }    
  63.     
  64.     searcher.close();
  65. } catch(ParseException e){
  66. System.out.println("ParseException ");
  67. } catch(IOException e){
  68. System.out.println("IOException  ");
  69. }
  70. }
  71. }