基于ASP.NET的lucene.net全文搜索实现步骤
程序员文章站
2024-03-05 13:21:55
在做项目的时候,需求添加全文搜索,选择了lucene.net方向,调研了一下,基本实现了需求,现在将它分享给大家。理解不深请多多包涵。
在完成需求的时候,查看的大量的资料...
在做项目的时候,需求添加全文搜索,选择了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格式的文件,搜索其他格式的文件在以后添加,主要核心思想就是提取各个不同格式文件的文本内容。
显示效果如下:
在以后的博文里继续接受搜索其他格式的文档。