Lucene.Net如何实现搜索结果分类统计功能

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

但由于搜易站内搜索系统是基于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的提升是双倍甚至几倍的,反之也是一样的。

posted @ 2017-03-03 10:00 kwklover 阅读(...) 评论(...) 编辑 收藏