栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP > php开源框架 > dedecms

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

dedecms 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

由于织梦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("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,重新构建检索分词结果。
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/5687.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号