DedeCms教程:优化DedeCMS搜索结果

由于DedeCMS搜索采用了分词,提升了搜索智能化,但是我们发现,搜索结果并没有变的更准确,本篇对DedeCMS的搜索进行一个优化,使它的搜索结果变的更智能、准确。

首先需要调整搜索页面的一个栏目关键词替换,找到/plus/search.php将其中58行代码

<pre class="brush:php;"> foreach($typeArr as $id=>$typename) { $keywordn = str_replace($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("SELECT spwords FROM `dede_search_keywords` WHERE keyword='".addslashes($keyword)."'; ");          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("/[ ]{1,}/", " ", $keywords);                  //var_dump($idx_keywords);exit();                  unset($sp);              }              else              {                  $keywords = $keyword;              }              $inquery = "INSERT INTO `dede_search_keywords`(`keyword`,`spwords`,`count`,`result`,`lasttime`)            VALUES ('".addslashes($keyword)."', '".addslashes($keywords)."', '1', '0', '".time()."'); ";              $this->dsql->ExecuteNoneQuery($inquery);          }          else          {              $this->dsql->ExecuteNoneQuery("UPDATE `dede_search_keywords` SET count=count+1,lasttime='".time()."' WHERE keyword='".addslashes($keyword)."'; ");              $keywords = $row['spwords'];          }          return $keywords;      }

最后,我们清空下数据表dede_search_keywords,重新构建检索分词结果,我们可以通过下面页面查看下分词的结果:http://www.cit.cn/plus/search.php?q=cit%D0%C5%CF%A2%CD%F8&searchtype=title

我们还会继续对DedeCMS搜索结果进行优化。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容