DedeCms教程:优化DedeCMS搜索结果

DedeCms教程:优化DedeCMS搜索结果,第1张

概述由于DedeCMS搜索采用了分词,提升了搜索智能化,但是我们发现,搜索结果并没有变的更准确,本篇对DedeCMS的搜索进行一个优化,使它的搜索结果变的更智能、准确。 首先需要调整搜索页面的一个栏目关键词替换,找到/plus/search. php 将其中58行 代码 : pr e

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

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

	修改为:

        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搜索结果进行优化。

总结

以上是内存溢出为你收集整理的DedeCms教程:优化DedeCMS搜索结果全部内容,希望文章能够帮你解决DedeCms教程:优化DedeCMS搜索结果所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://www.outofmemory.cn/zz/1061727.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-25
下一篇 2022-05-25

发表评论

登录后才能评论

评论列表(0条)

保存