最近我們搜易站內搜索系統的一個客戶需要一個無限級分類和分類統計功能,要實現的效果如下:
但由于搜易站內搜索系統是基于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的提升是雙倍甚至幾倍的,反之也是一樣的。
文章列表