• 手把手教你做关键词匹配项目(搜索引擎)---- 第十七天


    第十七天

    客串:屌丝的坑人表单神器

    起点:手把手教你做关键词匹配项目(搜索引擎)---- 第一天

    回顾:手把手教你做关键词匹配项目(搜索引擎)---- 第十六天

    小帅帅去落实黑名单录入的任务的时候,他给小丁丁讲解了半天,小丁丁就托着下巴,看着小帅帅,做着崇拜的表情。

    小帅帅感觉受打击了,跑到于老大那儿抱怨:于老大,我给小丁丁讲了半天,怎么装数据库客户端,怎么填黑名单,为什么要填都说明白了,小丁丁还是不懂,我真心受不了了。

    于老大就安慰小帅帅说:我们先不急着落实这项任务把,我们先把初步的功能做出来,把整个架子搭好,输入个宝贝就能匹配出关键词,前期的话关键词肯定很多不正确,但是不要紧,我们再来教。

    小帅帅:......

    于老大接着说到:只要他们看到了结果,应该很容易懂的,到时他们只有崇拜你的份啦。好了,小帅帅开心点,一次的碰壁很正常,只要在这里面吸取到教训就好了。

    小帅帅,心里虽然还有点不如意,不过没有刚开始那么气愤了。小帅帅答到:好吧,我先继续做功能先吧,我先去尝试做近义词的功能吧。

    近义词范例:

      1. XXL,加大,加大码
      2. 外套,衣,衣服,外衣,上衣
      3. 女款,女士,女生,女性


    考虑到某一个类目对于一些词的近义词有不同的定义,故而小帅帅把表结构设计成这样:

    CREATE TABLE `category_linklist` (
       `cid` BIGINT(20) DEFAULT NULL COMMENT '类目ID',
       `catmatch` VARCHAR(50) CHARACTER SET utf8 DEFAULT NULL COMMENT '类目名称',   
       `word` VARCHAR(255) CHARACTER SET utf8 DEFAULT NULL COMMENT '关键词,用逗号分隔',  
       `created` DATETIME DEFAULT NULL COMMENT '录入时间',
     ) ENGINE=INNODB DEFAULT CHARSET=utf8 COLLATE=utf8_bi

    小帅帅并把数据补了一些进去。

    INSERT INTO category_linklist(cid,catmatch,word) VALUES("50010850","女装","XXL,加大,加大码");
    INSERT INTO category_linklist(cid,catmatch,word) VALUES("50010850","女装","外套,衣,衣服,外衣,上衣");
    INSERT INTO category_linklist(cid,catmatch,word) VALUES("50010850","女装","女款,女士,女生,女性");
    #......

    小帅帅扩展了一个CharListHandle类来专门处理这些近义词.

    代码如下:

    <?php
    
    class LinklistCharListHandle extends CharListHandle {
        public function exec(){
            $sql = "select word from category_linklist where cid='$this->selectorItem->cid'";
            $linklist = DB::makeArray($sql);
            foreach($linklist as $strWords){
                $words = explode(",",$strWords);
    
                $properties = $this->selectorItem->getProperties();
                foreach($properties as $property){
    
                    $this->charlist->addCore($property->value);
                    if(in_array($property->value,$words)){
                        foreach($words as $char){
                            $this->charlist->addCore($char);
                        }
                    }
                }
            }
        }
    }

    小帅帅又增加了SelectorItem获取属性数组的接口:

    class SelectorItem {  
    
           #......
    
        public function getProperties(){
    
            $result = array();
            $properties = explode(";",$this->item->props_name);
            foreach($properties as $strProperty){
                $result[] = self::createItemProperty(explode(":",$strProperty));
            }
           return $result;
        }
    
        public static function createItemProperty($propertyArr){
            $property = new stdClass();
            $property->id = $propertyArr[0];
            $property->fieldId = $propertyArr[1];
            $property->name = $propertyArr[2];
            $property->value = $propertyArr[3];
            return $property;
        }
    
       #......
    }

    Selector的轻松改动如下:

    class Selector {
    
        private static $charListHandle = array(
            "黑名单" => "BacklistCharListHandle",
            "近义词" => "LinklistCharListHandle"
        );
    
        #......
    }

    当小帅帅把这代码拿给于老大看的时候,于老大只是瞧了一下,就把小帅帅给批了。

    小帅帅百思不得其解。

    预知小帅帅为啥被批,请看下回分解。

  • 相关阅读:
    EF4.3 到底能不能用?
    系统架构师(详解+转)
    silverlight MD5加密
    silverlight自定义安装客户端插件
    vs2010中文安装英文版silverlight5,和MVC 3
    如何自定义gridview的表格显示?
    Scott Mitchell的ASP.NET2.0数据指南中文版索引
    成功软件开发者的9种编程习惯(一)
    第8章 商品目录管理
    6/29 项目目录结构有所调整
  • 原文地址:https://www.cnblogs.com/oshine/p/3937229.html
Copyright © 2020-2023  润新知