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

第十七天

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

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

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

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

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

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

小帅帅:......

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

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

近义词范例:

  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"
    );

    #......
}

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

小帅帅百思不得其解。

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

posted @ 2014-08-26 14:32  oShine.Q  阅读(1064)  评论(0编辑  收藏  举报