校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 基于ASP.NET的lucene.net全文搜索實現步驟

基于ASP.NET的lucene.net全文搜索實現步驟

熱門標簽:蘋果手機凱立德地圖標注 電話機器人軟件銷售工作 百度ai地圖標注 同安公安400電話怎么申請流程 玉林市機器人外呼系統哪家好 預測式外呼系統使用說明 申請400電話手續 合肥電銷外呼系統哪家公司做的好 南陽外呼系統定制化

在做項目的時候,需求添加全文搜索,選擇了lucene.net方向,調研了一下,基本實現了需求,現在將它分享給大家。理解不深請多多包涵。

在完成需求的時候,查看的大量的資料,本文不介紹詳細的lucene.net工程建立,只介紹如何對文檔進行全文搜索。對于如何建立lucene.net的工程請大家訪問

使用lucene.net搜索分為兩個部分,首先是創建索引,創建文本內容的索引,其次是根據創建的索引進行搜索。那么如何對文檔進行索引呢,主要是對文檔的內容進行索引,關鍵是提取出文檔的內容,按照常規實現,由簡到難,提取txt格式的文本相對比較簡單,如果實現了提取txt文本,接下來就容易多了,萬丈高樓平地起,這就是地基。

1.首先創建ASP.NET頁面。

這是一個極其簡單的頁面,創建頁面之后,雙擊各個按鈕生成相應的點擊事件,在相應的點擊事件中實現程序設計。

2.實現索引部分。

前面已經說到了,索引主要是根據文本內容建立索引,所以要提取文本內容。創建提取txt格式文檔文本內容的函數。

復制代碼 代碼如下:
 
//提取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;
}

文本內容已經提取出來了,接下來要根據提取的內容建立索引
復制代碼 代碼如下:
 
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.索引創建完了,接下來就是搜索,搜索只要按照固定的格式書寫不會出現錯誤。
復制代碼 代碼如下:
 
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格式的文件,搜索其他格式的文件在以后添加,主要核心思想就是提取各個不同格式文件的文本內容。

顯示效果如下:

在以后的博文里繼續接受搜索其他格式的文檔。

您可能感興趣的文章:
  • Lucene.Net實現搜索結果分類統計功能(中小型網站)
  • Java實現lucene搜索功能的方法(推薦)
  • 基于Lucene的Java搜索服務器Elasticsearch安裝使用教程
  • 使用Java的Lucene搜索工具對檢索結果進行分組和分頁
  • 使用Lucene.NET實現站內搜索
  • 使用Lucene實現一個簡單的布爾搜索功能

標簽:南京 嘉興 南昌 南京 海南 淄博 臺州 揚州

巨人網絡通訊聲明:本文標題《基于ASP.NET的lucene.net全文搜索實現步驟》,本文關鍵詞  基于,ASP.NET,的,lucene.net,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于ASP.NET的lucene.net全文搜索實現步驟》相關的同類信息!
  • 本頁收集關于基于ASP.NET的lucene.net全文搜索實現步驟的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 惠州市| 卢湾区| 建湖县| 芮城县| 金华市| 密山市| 西宁市| 福海县| 游戏| 曲松县| 江达县| 陕西省| 绥滨县| 漳州市| 霍山县| 会同县| 冷水江市| 长泰县| 登封市| 光泽县| 抚州市| 依兰县| 茌平县| 绥中县| 蒙城县| 赤水市| 遂平县| 大连市| 竹山县| 泰安市| 怀柔区| 北流市| 临沭县| 汤原县| 绥宁县| 麦盖提县| 龙州县| 商都县| 且末县| 张家口市| 辽宁省|