创建索引库

 
       //读取文件,存储到索引库
 
        public string CreateDatebase()
        {
        //获取索引库的路径
            var indexPath = AppDomain.CurrentDomain.BaseDirectory + ConfigurationManager.AppSettings["IndexDateBase"];
            FSDirectory directory = FSDirectory.Open(new DirectoryInfo(indexPath), new NoLockFactory());
            IndexReader reader = IndexReader.Open(directory, true);
            var searcher = new IndexSearcher(reader);
            //搜索条件
            var query = new PhraseQuery();
            foreach (string word in GetPanGuAnalyzer(str))//先用空格,让用户去分词,空格分隔的就是词“计算机   专业”
            {
                query.Add(new Term("body", word));
            }
            //组成词的字之间可以允许的距离
            query.SetSlop(5);
            TopScoreDocCollector collector = TopScoreDocCollector.create(1000, true);
            searcher.Search(query, null, collector);//根据query查询条件进行查询,查询结果放入collector容器
            ScoreDoc[] docs = collector.TopDocs(0, collector.GetTotalHits()).scoreDocs;//得到所有查询结果中的文档,GetTotalHits():表示总条数   TopDocs(300, 20);//表示得到300(从300开始),到320(结束)的文档内容.
            var  list = new List<string>();
            for (int i = 0; i < docs.Length; i++)
            {
                int docId = docs[i].doc;//得到查询结果文档的id(Lucene内部分配的id)
                Document doc = searcher.Doc(docId);//找到文档id对应的文档详细信息
                var _str = doc.Get("body");
                list.Add(_str);
            }
            ViewBag.List = list;
            return View();

}

进行搜索

 
       public ActionResult List(string  str)
        {
            //获取索引库的路径
            var indexPath = AppDomain.CurrentDomain.BaseDirectory + ConfigurationManager.AppSettings["IndexDateBase"];
            FSDirectory directory = FSDirectory.Open(new DirectoryInfo(indexPath), new NoLockFactory());
            IndexReader reader = IndexReader.Open(directory, true);
            var searcher = new IndexSearcher(reader);
            //搜索条件
            var query = new PhraseQuery();
            foreach (string word in GetPanGuAnalyzer(str))//先用空格,让用户去分词,空格分隔的就是词“计算机   专业”
            {
                query.Add(new Term("body", word));
            }
            //组成词的字之间可以允许的距离
            query.SetSlop(5);
            TopScoreDocCollector collector = TopScoreDocCollector.create(1000, true);
            searcher.Search(query, null, collector);//根据query查询条件进行查询,查询结果放入collector容器
            ScoreDoc[] docs = collector.TopDocs(0, collector.GetTotalHits()).scoreDocs;//得到所有查询结果中的文档,GetTotalHits():表示总条数   TopDocs(300, 20);//表示得到300(从300开始),到320(结束)的文档内容.
            var  list = new List<string>();
            for (int i = 0; i < docs.Length; i++)
            {
                int docId = docs[i].doc;//得到查询结果文档的id(Lucene内部分配的id)
                Document doc = searcher.Doc(docId);//找到文档id对应的文档详细信息
                var _str = doc.Get("body");
                list.Add(_str);
            }
            ViewBag.List = list;
            return View();
        }
        /// 对传递过来的字符串进行盘古分词
        /// </summary>
        /// <returns></returns>
        public static List<string> GetPanGuAnalyzer(string txt)
        {
            List<string> list = new List<string>();
            Analyzer analyzer = new PanGuAnalyzer();
            TokenStream tokenStream = analyzer.TokenStream("", new StringReader(txt));
            Lucene.Net.Analysis.Token token = null;
            while ((token = tokenStream.Next()) != null)
            {
                list.Add(token.TermText());
            }
            return list;
        }

IndexReader 删除数据

 //获取字典
            var directory = LucenceHelp.GetDirectory();
            //先删除数据
            IndexReader reader = IndexReader.Open(directory);
            reader.DeleteDocuments(new Term("number", "0"));
            reader.IsOptimized();
            reader.Close();

IndexWriter 删除数据

 
//获取字典
            var directory = LucenceHelp.GetDirectory();
            var writer = new IndexWriter(directory, new PanGuAnalyzer(), false, IndexWriter.MaxFieldLength.UNLIMITED);
            //删除的是与要匹配的关键字相关的文件
            var term = new Term("body", name);
            //删除的是文件名为13的文件
            //var term = new Term("number", "13");
            writer.DeleteDocuments(term);
            writer.Optimize();
            writer.Close();

修改索引

            Analyzer analyzer = new PanGuAnalyzer();
            //获取字典
             var directory = LucenceHelp.GetDirectory();
            //先删除数据
            IndexReader reader = IndexReader.Open(directory);
            reader.DeleteDocuments(new Term("number", "0"));
            reader.Close();
            //再添加数据
            IndexWriter writer = new IndexWriter(directory, analyzer, false, IndexWriter.MaxFieldLength.LIMITED);
            Document document = new Document();
            document.Add(new Field("number", "0", Field.Store.YES, Field.Index.ANALYZED));
            document.Add(new Field("body", "如家快捷酒店-0", Field.Store.YES, Field.Index.ANALYZED));
            writer.AddDocument(document);
            writer.Close();  
   

要添加的文件

最新文章

  1. 初步了解nodejs
  2. uva11426 gcd、欧拉函数
  3. Team Queue (uva540 队列模拟)
  4. Qt之线程基础
  5. Best Cow Fences_二分&amp;&amp;DP
  6. 【Android 界面效果20】Android GradientDrawable类的详解,设置activity的背景颜色渐变效果
  7. 译文:User-agent的历史
  8. SQL中的存储过程和函数
  9. C#连接六类数据库的代码集
  10. C#编写影院售票系统(A project with a higher amount of gold )
  11. laravel5.5 延时队列的使用
  12. linux extglob模式 和rm反选
  13. go生成不重复的纯数字6位的随机数
  14. java爬知乎问题的所有回答
  15. page.isvalid
  16. 腾讯云CDN python SDK
  17. linux暂停一个在运行中的进程【转】
  18. 用函数打印Hello js
  19. opencv-resize()放缩函数简介
  20. Python全栈开发-执行字符串形式的语句和字符串形式的表达式方法(即exec和eval方法)

热门文章

  1. 继承ViewGroup研究(汇总) 一、二、三
  2. c# 搭建服务端 byte[] 处理(3)
  3. CSS实现宽高成比例缩放
  4. Swift学习笔记:类和结构
  5. Pro Android学习笔记(十一):了解Intent(中)
  6. 前端新人学习笔记-------html/css/js基础知识点
  7. Git上手指南
  8. JavaScript之JS的执行环境和作用域
  9. &lt;转&gt;ASP.NET学习笔记之理解MVC底层运行机制
  10. SQL Server中 sysobjects、syscolumns、systypes