zoukankan      html  css  js  c++  java
  • Lucene-全文索引

              近期接触了lucene,我想也有非常多人以前听过,于是带着好奇心,我開始对lucene进行了解,给我影响最深的是它非常多的应用了索引表,这个工具之所以快是就是由于大量引用到了索引表。今天仅仅说下我刚開始做的校历样例,创建索引。

    以下对lucene从概念上做个介绍,Lucene是一个信息检索的函数库(Library),利用它你能够为你的应用加上索引和搜索的功能.Lucene的使用者不须要深入了解有关全文检索的知识,只学会使用库中的一个类,你就为你的应用实现全文检索的功能.不过千万别以为Lucene是一个象google那样的搜索引擎,Lucene甚至不是一个应用程序,它不过一个工具,一个Library.你也能够把它理解为一个将索引,搜索功能封装的非常好的一套简单易用的API.利用这套API你能够做非常多有关搜索的事情,并且非常方便.  

              那么lucene能够做什么呢?Lucene能够对不论什么的数据做索引和搜索. Lucene无论数据源是什么格式,仅仅要它能被转化为文字的形式,就能够被Lucene所分析利用.也就是说无论是MS word, Html ,pdf还是其它什么形式的文件仅仅要你能够从中抽取出文字形式的内容就能够被Lucene所用.你就能够用Lucene对它们进行索引以及搜索. 以下是我做的一个小样例,就是一个查询生成索引的样例:

    <span style="font-size:14px;">package com.jikexueyuan.study;
    import java.io.File;
    import java.io.IOException;
    import org.apache.lucene.analysis.Analyzer;
    import org.apache.lucene.analysis.standard.StandardAnalyzer;
    import org.apache.lucene.document.Document;
    import org.apache.lucene.document.IntField;
    import org.apache.lucene.document.Field.Store;
    import org.apache.lucene.document.StringField;
    import org.apache.lucene.index.IndexWriter;
    import org.apache.lucene.index.IndexWriterConfig;
    import org.apache.lucene.index.IndexWriterConfig.OpenMode;
    import org.apache.lucene.store.Directory;
    import org.apache.lucene.store.FSDirectory;
    import org.apache.lucene.util.Version;
    public class IndexCreate {
    
    	/**
    	 * @param args
    	 */
    	public static void main(String[] args) {
    		// TODO Auto-generated method stub
    		Analyzer analyzer=new StandardAnalyzer(Version.LUCENE_46);//StandardAnalyzer是将英文依照空格、标点符号等进行分词。将中文依照单个字进行分词。一个汉字算一个词
    		IndexWriterConfig indexWriterConfig=new IndexWriterConfig(Version.LUCENE_46,analyzer);//把写入的文件用指定的分词器将文章分词(这样检索的时候才干查的快),然后将词放入索引文件。
    		indexWriterConfig.setOpenMode(OpenMode.CREATE_OR_APPEND);
    		Directory directory=null;
    		IndexWriter indexWriter=null;
    		try {
    			directory=FSDirectory.open(new File("E://index/test"));// //索引库存放在这个目录里  ,Directory表示索引文件保存的地方,是抽象类,两个子类FSDirectory表示文件里,RAMDirectory 表示存储在内存中  
    			if(indexWriter.isLocked(directory)){
    				indexWriter.unlock(directory);
    			}
    			indexWriter=new IndexWriter(directory,indexWriterConfig);
    		} catch (Exception e) {
    			e.printStackTrace();
    		}
    		
    		//Document document=new Document();
    		Document doc = new Document();
    		doc.add(new StringField("id","abcde", Store.YES));
    		doc.add(new org.apache.lucene.document.TextField("content","极客学院",Store.YES));
    		doc.add(new IntField("num",1,Store.YES));
    		
    		try {
    			indexWriter.addDocument(doc);//向索引中加入文档(Insert)
    		} catch (Exception e) {
    			
    			e.printStackTrace();
    			
    		}
    		
    		Document doc1 = new Document();
    		doc1.add(new StringField("id","sdfsd", Store.YES));
    		doc1.add(new org.apache.lucene.document.TextField("content","Lucene案例",Store.YES));
    		doc1.add(new IntField("num",1,Store.YES));
    		
    		try {
    			indexWriter.addDocument(doc1);
    		} catch (Exception e) {
    			
    			e.printStackTrace();
    			
    		}
    		try {
    			indexWriter.commit();
    			indexWriter.close();
    			directory.close();
    		} catch (Exception e) {
    			// TODO Auto-generated catch block
    			e.printStackTrace();
    		}
    	}
    }
    </span>


            结果会生成一系列的有关索引的文件。例如以下图:

             从上面的样例我们能够看出创建索引须要的三个要素各自是:

              1、indexWriter

              2、Directory

              3、Anayzer

              4、Document

             5、Field

          对于lucene的分享还要继续。希望有越来越多的人能够共同努力!

  • 相关阅读:
    判断闰年
    正向代理(Forward Proxy)与反向代理(Reverse Proxy)
    What do we need to know about Vue.js?(译)
    How To Create A GitHub Profile README(译)
    Building a carousel component in React using Hooks(译)
    What is Redux JS(译)
    Weekly Contest 197
    koa-compose源码阅读与学习
    js 事件循环消息队列和微任务宏任务
    记一次字节跳动的面试
  • 原文地址:https://www.cnblogs.com/gcczhongduan/p/5154908.html
Copyright © 2011-2022 走看看