`
nnwq
  • 浏览: 209833 次
社区版块
存档分类
最新评论

基于ASP.NET的lucene.net全文搜索(one)

 
阅读更多

在做项目的时候,需求添加全文搜索,选择了lucene.net方向,调研了一下,基本实现了需求,现在将它分享给大家。理解不深请多多包涵。

在完成需求的时候,查看的大量的资料,本文不介绍详细的lucene.net工程建立,只介绍如何对文档进行全文搜索。对于如何建立lucene.net的工程请大家访问

lucene.net开发

使用lucene.net搜索分为两个部分,首先是创建索引,创建文本内容的索引,其次是根据创建的索引进行搜索。那么如何对文档进行索引呢,主要是对文档的内容进行索引,关键是提取出文档的内容,按照常规实现,由简到难,提取txt格式的文本相对比较简单,如果实现了提取txt文本,接下来就容易多了,万丈高楼平地起,这就是地基。

1.首先创建ASP.NET页面。

 

 

这是一个极其简单的页面,创建页面之后,双击各个按钮生成相应的点击事件,在相应的点击事件中实现程序设计。

2.实现索引部分。

前面已经说到了,索引主要是根据文本内容建立索引,所以要提取文本内容。创建提取txt格式文档文本内容的函数。

View Code 

 //提取txt文件

      public static string FileReaderAll(FileInfo fileName)

     {

          //读取文本内容,并且默认编码格式,防止出现乱码

          StreamReader reader = new StreamReader(fileName.FullName, System.Text.Encoding.Default);

         string line = "";

          string temp = "";

          //循环读取文本内容

          while ((line = reader.ReadLine()) != null)

        {

             temp += line;

        }

        reader.Close();

         //返回字符串,用于lucene.net生成索引         return temp;

     }

 

文本内容已经提取出来了,接下来要根据提取的内容建立索引

View Code 

 protected void Button2_Click(object sender, EventArgs e)

     {

          //判断存放文本的文件夹是否存在

          if (!System.IO.Directory.Exists(filesDirectory))

         {

              Response.Write("<script>alert('指定的目录不存在');</script>");

              return;

         }

          //读取文件夹内容

         DirectoryInfo dirInfo = new DirectoryInfo(filesDirectory);

         FileInfo[] files = dirInfo.GetFiles("*.*");

         //文件夹判空

         if (files.Count() == 0)

        {

             Response.Write("<script>alert('Files目录下没有文件');</script>");

             return;

        }

         //判断存放索引的文件夹是否存在,不存在创建

         if (!System.IO.Directory.Exists(indexDirectory))

        {

            System.IO.Directory.CreateDirectory(indexDirectory);

        }

         //创建索引

        IndexWriter writer = new IndexWriter(FSDirectory.Open(new DirectoryInfo(indexDirectory)),

                 analyzer, true, IndexWriter.MaxFieldLength.LIMITED);

         

         for (int i = 0; i < files.Count(); i++)

        {

            string str = "";

            FileInfo fileInfo = files[i];

             //判断文件格式,为以后其他文件格式做准备

            if (fileInfo.FullName.EndsWith(".txt") || fileInfo.FullName.EndsWith(".xml"))

            {

                 //获取文本

                 str = FileReaderAll(fileInfo);

            }            

             Lucene.Net.Documents.Document doc = new Lucene.Net.Documents.Document();

             doc.Add(new Lucene.Net.Documents.Field("FileName", fileInfo.Name, Lucene.Net.Documents.Field.Store.YES, Lucene.Net.Documents.Field.Index.ANALYZED));

             //根据文本生成索引

             doc.Add(new Lucene.Net.Documents.Field("Content", str, Lucene.Net.Documents.Field.Store.YES, Lucene.Net.Documents.Field.Index.ANALYZED));

             doc.Add(new Lucene.Net.Documents.Field("Path", fileInfo.FullName, Lucene.Net.Documents.Field.Store.YES, Lucene.Net.Documents.Field.Index.NO));

             //添加生成的索引

            writer.AddDocument(doc);

            writer.Optimize();            

        }        

        writer.Dispose();

         Response.Write("<script>alert('索引创建成功');</script>");

     }

 

3.索引创建完了,接下来就是搜索,搜索只要按照固定的格式书写不会出现错误。

View Code 

 protected void Button1_Click(object sender, EventArgs e)

     {

          //获取关键字

          string keyword = TextBox1.Text.Trim();

         int num = 10;

          //关键字判空

          if (string.IsNullOrEmpty(keyword))

        {

             Response.Write("<script>alert('请输入要查找的关键字');</script>");

             return;

        }

 

         IndexReader reader = null;

         IndexSearcher searcher = null;

         try

        {

             reader = IndexReader.Open(FSDirectory.Open(new DirectoryInfo(indexDirectory)), true);

             searcher = new IndexSearcher(reader);

            //创建查询

             PerFieldAnalyzerWrapper wrapper = new PerFieldAnalyzerWrapper(analyzer);

             wrapper.AddAnalyzer("FileName", analyzer);

             wrapper.AddAnalyzer("Path", analyzer);

             wrapper.AddAnalyzer("Content", analyzer);

             string[] fields = { "FileName", "Path", "Content" };

 

             QueryParser parser = new MultiFieldQueryParser(Lucene.Net.Util.Version.LUCENE_30, fields, wrapper);

             //根据关键字查询

            Query query = parser.Parse(keyword);                        

            TopScoreDocCollector collector = TopScoreDocCollector.Create(num, true);

            searcher.Search(query, collector);

             //这里会根据权重排名查询顺序

             var hits = collector.TopDocs().ScoreDocs;

 

             int numTotalHits = collector.TotalHits;

             

             //以后就可以对获取到的collector数据进行操作

             for (int i = 0; i < hits.Count(); i++)

            {

                 var hit = hits[i];

                 Lucene.Net.Documents.Document doc = searcher.Doc(hit.Doc);

                 Lucene.Net.Documents.Field fileNameField = doc.GetField("FileName");

                 Lucene.Net.Documents.Field pathField = doc.GetField("Path");

                 Lucene.Net.Documents.Field contentField = doc.GetField("Content");                 //在页面循环输出表格

                 strTable.Append("<tr>");

                strTable.Append("<td>" + fileNameField.StringValue + "</td>");

                 strTable.Append("</tr>");

                 strTable.Append("<tr>");

                 strTable.Append("<td>" + pathField.StringValue + "</td>");

                 strTable.Append("</tr>");

                 strTable.Append("<tr>");

                 strTable.Append("<td>" + contentField.StringValue.Substring(0, 300) + "</td>");

                 strTable.Append("</tr>");

           }

        }

         finally

       {

          if (searcher != null)

                searcher.Dispose();     

        if (reader != null)

              reader.Dispose();

       }

     }

 

现在整个lucene.net搜索全文的过程就建立完了,现在可以搜索txt格式的文件,搜索其他格式的文件在以后添加,主要核心思想就是提取各个不同格式文件的文本内容。

显示效果如下:

 

在以后的博文里继续接受搜索其他格式的文档。

0
1
分享到:
评论

相关推荐

    【ASP.NET编程知识】基于ASP.NET的lucene.net全文搜索实现步骤.docx

    在ASP.NET开发中,有时候我们需要为项目添加全文搜索功能,这时可以借助开源搜索引擎库Lucene.NET。Lucene.NET是一个高性能、可扩展的信息检索库,可以处理大量文本数据并提供高效的搜索服务。以下是一些关于如何在...

    基于ASP.net的企业文件管理系统源码.zip

    5. **搜索功能**:可能采用了全文搜索引擎(如Lucene.NET)或SQL Server的全文搜索,实现对文件内容的快速检索。 6. **版本控制**:为了管理文件的历史版本,系统可能实现了版本控制功能,允许用户查看和恢复旧版本...

    .Net Lucene+盘古分词站内搜索

    本文将深入探讨如何结合.Net框架与Lucene搜索引擎库,搭配盘古分词工具,来构建一个强大的站内搜索系统,特别强调字典更新维护的重要性。 首先,让我们了解Lucene。Lucene是Apache软件基金会的一个开源项目,它是一...

    Lucene.Net 实现全文检索

    Lucene.Net 是一个基于 Apache Lucene 的开源全文搜索引擎库,专为 .NET Framework 平台设计。它提供了一套高级文本搜索程序库,让开发者能够在 .NET 应用程序中轻松实现全文检索功能。在本案例中,我们将在 .Net ...

    基于ASP.NET的论坛 (BBS)

    这可能需要利用SQL查询或者全文搜索引擎如Lucene.NET。 5. **通知与提醒**:当有新回复或私信时,通过电子邮件、站内消息等方式通知用户,增加用户互动性。 6. **界面设计**:使用ASP.NET的控件和CSS样式来创建...

    毕业设计,基于ASP.NET+Lucene+SqlServer开发的搜索引擎,内含完整源代码,数据库,毕业论文

    毕业设计,基于ASP.NET+Lucene+SqlServer开发的搜索引擎,内含完整源代码,数据库,毕业论文 通过搜索引擎从互联网上获取有用信息已经成为人们生活的重要组成部分,Lucene是构建搜索引擎的其中一种方式。搜索引擎...

    基于Lucene.Net垂直搜索引擎源码

    基于Lucene.Net垂直搜索引擎完全开源版.rar

    基于ASP.NET动漫管理系统(适合初学者,有说明书,很详细易改易参考)

    4. 搜索模块:实现关键词搜索,可能需要用到SQL查询语句的全文检索功能,或者使用Lucene.NET等全文搜索引擎。 5. 评论与互动模块:用户对动漫进行评价和讨论,涉及AJAX异步请求以实现实时交互,可能使用jQuery或...

    .NET lucene 源代码

    《深入理解.NET Lucene搜索引擎库》 在.NET开发领域中,Lucene是一个广泛使用的全文搜索引擎库,它提供了强大的文本分析和搜索功能。标题中的".NET Lucene 源代码"表明我们将探讨的是如何在.NET环境下利用Lucene...

    基于ASP.NET的lucene.net全文搜索实现步骤

    在做项目的时候,需求添加全文搜索,选择了lucene.net方向,调研了一下,基本实现了需求,现在将它分享给大家。理解不深请多多包涵。 在完成需求的时候,查看的大量的资料,本文不介绍详细的lucene.net工程建立,只...

    基于.NET平台的Lucene.Net全文搜索引擎设计源码

    本项目是一款基于.NET平台的Lucene.Net全文搜索引擎设计源码,包含4997个文件,其中C#源文件占主导,共计3766个,辅以Markdown、文本、YAML、项目文件、压缩包、JSON、PowerShell脚本、Affinity文件、部分文件等类型...

    基于ASP.Net和Lucene.Net开发的站内搜索引擎Demo源码+项目说明+sln解决方案.zip

    基于ASP.Net和Lucene.Net开发的站内搜索引擎Demo源码+项目说明+sln解决方案.zip 1)EDC.SearchEngine.Dao  顾名思义,数据访问层,与数据库进行交互,各种SQL! (2)EDC.SearchEngine.Service  业务逻辑层,对...

    基于ASP.net+Ajax+Lucene的构建搜索引擎源码.zip

    《构建基于ASP.NET + AJAX + Lucene的搜索引擎》 在当今信息爆炸的时代,搜索引擎成为了获取信息的关键工具。本文将深入探讨如何使用ASP.NET、AJAX和Lucene这三种技术来构建一个高效的搜索引擎。ASP.NET是微软公司...

    使用Lucene.net进行全文搜索

    总结来说,Lucene.NET为.NET开发者提供了强大的全文搜索工具,通过构建索引、多关键字匹配、搜索执行和结果处理,可以构建高效、灵活的全文搜索引擎。在实际应用中,根据需求可以进一步定制Analyzer、Query和结果...

    asp.net mvc使用LucenceNet

    而Lucene.Net是Apache Lucene项目的一个.NET版本,是一个全文搜索引擎库,适用于多种.NET应用,包括ASP.NET MVC项目。本文将深入探讨如何在ASP.NET MVC项目中集成并使用LuceneNet,以及其在索引和搜索方面的应用。 ...

    Lucene.Net实现全文搜索

    **Lucene.Net** 是一个基于 .NET 的高性能全文检索引擎库。它最初由 Java 版本的 Lucene 发展而来,旨在为 .NET 开发者提供一个强大而灵活的搜索解决方案。随着项目的演进,Lucene.Net 经历了从开源到商业化的转变。...

    autoSearch 基于Lucene.Net的站内搜索

    对于C#开发者来说,利用开源全文搜索引擎Lucene.Net实现站内搜索是一个高效且灵活的选择。本篇将深入探讨如何利用Lucene.Net构建一个自定义的站内搜索解决方案。 Lucene.Net是Apache Lucene的.NET版本,它为开发...

    基于lucene.net开发的个人知识库

    Lucene.Net,作为Apache Lucene项目的一个.NET版本,为开发者提供了强大的全文搜索引擎库,使得开发者能够轻松构建自己的知识管理系统。这个项目,即“基于Lucene.Net开发的个人知识库”,展示了如何利用这一工具来...

    Lucene.Net.rar 2.0 ver asp.net 组件

    总结来说,Lucene.Net 2.0 for ASP.NET组件是一个强大的全文搜索解决方案,它为.NET开发者提供了构建高效、灵活的搜索引擎的工具。通过深入理解和熟练使用这个组件,开发者可以提升其应用程序的用户体验,提供更智能...

    自己修改的基于lucene.net 2.9和highlighter插件的简单例子

    Lucene.NET是Apache Lucene搜索引擎库的.NET版本,用于实现全文检索和分析功能。而Highlighter插件则是Lucene中用于高亮显示搜索关键词的部分,它可以帮助用户在大量文本中快速定位和识别搜索结果。 **Lucene.NET**...

Global site tag (gtag.js) - Google Analytics