博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Lucene.Net如何实现搜索结果分类统计功能
阅读量:5956 次
发布时间:2019-06-19

本文共 933 字,大约阅读时间需要 3 分钟。

最近我们的一个客户需要一个无限级分类和分类统计功能,要实现的效果如下:

但由于是基于Lucene.net 2.0开发的,并没有内置的分类统计搜索功能,于是乎只能自己实现了,考虑到客户的总数据量和搜索量不是特别大,于是用了简单有效的方式来实现:

因为涉及到分类的操作,但是每个站点的分类体系还是有些不一样的,本文主要提供思路和部分演示代码,给有需要的童鞋参考:

思路:

首先想到Lucene搜索出来的结果是一个Hits对象,Hits其实就是一个搜索结果文档的集合对象,那么遍历这个集合对象,跟给定的分类字段比对,存在就+1 。

代码示例:

Lucene.Net.Search.Hits hits = Searcher.Search(querystring) ;

int hcount = hits.Length();

Lucene.Net.Documents.Document doc = null;

for (int i = 0; i < hcount; i++)
{
    doc = hits.Doc(i);
    string c1 = doc.GetField("Cate1").StringValue();

     //判断是否存在于给定的分类集合中,存在则加1

    if (parameter.Cate1Groups.ContainsKey(c1))

    {
        parameter.Cate1Groups[c1] = parameter.Cate1Groups[c1] + 1;
    }
    else
    {
        parameter.Cate1Groups.Add(c1, 1);
    }
}

 

适用场景:

这种实现方式比较适合中小型网站,在数据量和搜索量不大的情况下可用。

 

题外话:

以前一直觉得,作为一个中小型网站,搜索的筛选不应该太多,毕竟海量数据的百度,谷歌都简单到只有一个搜索框,后来经过跟一些站长的交流后发现,其实并不是的这样的,有些网站,比如图片,素材,资源类网站,用户对这类网站的站内搜索的使用频率非常高的,对搜索质量,效率和精准筛选有比较高的要求,搜索的PV占比整站PV的比重是很高,如果搜索做的不好,对流量影响非常大,因为站内搜索好用的话,对PV的提升是双倍甚至几倍的,反之也是一样的。

转载地址:http://ssexx.baihongyu.com/

你可能感兴趣的文章
java this关键字的使用
查看>>
linux基础1
查看>>
jquery之统计数字parseFloat
查看>>
20161121
查看>>
Nginx服务器开启gzip压缩功能额必要性
查看>>
ZeroMQ研究与应用分析
查看>>
Linux基础命令--grep/find
查看>>
NTFS(Windows)、ext4(RHEL6)和xfs(RHEL7)文件系统的误删除恢复和备份
查看>>
[python] raw string,反斜杠\,re Lib
查看>>
6.1-6.4 压缩打包介绍,压缩工具gzip,bzip2, xz
查看>>
如何用代码爬抓电商数据(附淘宝API调用实例)
查看>>
远程连接windows系统提示:其他用户要远程登录,需要通过远程桌面服务进行登录的权限......
查看>>
html5的移动开发二重身份需求
查看>>
我的友情链接
查看>>
10个SQL注入工具
查看>>
[李景山php]每天laravel-20160826|EncryptionServiceProvider
查看>>
[李景山php]每天laravel-20161005|Validator.php-5
查看>>
php读取大文件详解【OK】
查看>>
Gnome 快捷键汇总
查看>>
通过注册表修改我的文档等系统文件夹默认位置
查看>>