Moke|墨客

 找回密码
 立即注册
搜索
查看: 8884|回复: 0

DedeCms教程:精确优化搜索结果

[复制链接]

3636

主题

0

回帖

3681

积分

超级版主

Rank: 8Rank: 8

积分
3681
发表于 2016-5-9 15:29:46 | 显示全部楼层 |阅读模式



                  由于DedeCMS搜索采用了分词,提升了搜索智能化,但是我们发现,搜索结果并没有变的更准确,本篇对DedeCMS的搜索进行一个优化,使它的搜索结果变的更智能、准确。
  首先需要调整搜索页面的一个栏目关键词替换,找到/plus/search.php将其中58行代码:
foreach($typeArr as $id=>$typename) {   $keywordn = str_replac($typename, ' ', $keyword);   if($keyword != $keywordn)   {  修改为:
foreach($typeArr as $id=>$typename){    //$keywordn = str_replace($typename, ' ', $keyword);    $keywordn = $keyword;    if($keyword != $keywordn)    {  然后,我们再调整下分词检索的类,找到/include/arc.searchview.class.php,找到function GetKeywords($keyword)这个类的方法,替换为:
function GetKeywords($keyword){    global $cfg_soft_lang;    $keyword = cn_substr($keyword, 50);    $row = $this->dsql->GetOne(&quot;SELECT spwords FROM `dede_search_keywords` WHERE keyword='&quot;.addslashes($keyword).&quot;'; &quot;);    if(!is_array($row))    {        if(strlen($keyword)>7)        {            $sp = new SplitWord($cfg_soft_lang, $cfg_soft_lang);            $sp->SetSource($keyword, $cfg_soft_lang, $cfg_soft_lang);            $sp->SetResultType(2);            $sp->StartAnalysis(TRUE);            $keywords = $sp->GetFinallyResult();            $idx_keywords = $sp->GetFinallyIndex();            ksort($idx_keywords);            $keywords = $keyword.' ';            foreach ($idx_keywords as $key => $value) {                if (strlen($key) <= 3) {                    continue;                }                $keywords .= ' '.$key;            }            $keywords = preg_replace(&quot;/[ ]{1,}/&quot;, &quot; &quot;, $keywords);            //var_dump($idx_keywords);exit();            unset($sp);        }        else        {            $keywords = $keyword;        }        $inquery = &quot;INSERT INTO `dede_search_keywords`(`keyword`,`spwords`,`count`,`result`,`lasttime`)      VALUES ('&quot;.addslashes($keyword).&quot;', '&quot;.addslashes($keywords).&quot;', '1', '0', '&quot;.time().&quot;'); &quot;;        $this->dsql->ExecuteNoneQuery($inquery);    }    else    {        $this->dsql->ExecuteNoneQuery(&quot;UPDATE `dede_search_keywords` SET count=count+1,lasttime='&quot;.time().&quot;' WHERE keyword='&quot;.addslashes($keyword).&quot;'; &quot;);        $keywords = $row['spwords'];    }    return $keywords;}  最后,我们清空下数据表dede_search_keywords,重新构建检索分词结果。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

 

 

快速回复 返回顶部 返回列表