Table of Contents
Teach you step by step how to do keyword matching projects (search engines) ---- Day 17, teach you how to do it. Day 17
Home Backend Development PHP Tutorial Teach you step by step how to do a keyword matching project (search engine) ---- Day 17, teach you how to do it on Day 17_PHP Tutorial

Teach you step by step how to do a keyword matching project (search engine) ---- Day 17, teach you how to do it on Day 17_PHP Tutorial

Jul 13, 2016 am 10:20 AM
- Do Key words match Hand in hand search engine teach you project

Teach you step by step how to do keyword matching projects (search engines) ---- Day 17, teach you how to do it. Day 17

Day 17

Guest appearance: Diaosi’s deceptive form artifact

Starting point: Teach you step by step how to do keyword matching project (search engine) ---- Day 1

Review: Teach you step by step how to do keyword matching project (search engine) ---- Day 16

When Xiao Shuaishuai went to implement the blacklist entry task, he explained it to Xiao Dingding for a long time. Xiao Dingding held his chin and looked at Xiao Shuaishuai with an expression of admiration.

Xiao Shuai Shuai felt shocked and ran to Boss Yu to complain: Boss Yu, I talked to Xiao Ding Ding for a long time about how to install the database client, how to fill in the blacklist, and why it was necessary to fill it in. I made it clear to Xiao Ding Ding. I still don’t understand, I really can’t stand it anymore.

Boss Yu comforted Xiao Shuaishuai and said: Let’s not rush to implement this task. Let’s make the preliminary functions first, set up the entire shelf, and input a baby to match the keywords. In the early stage, There are definitely many incorrect keywords, but it doesn’t matter, we will teach you again.

Xiao Shuai Shuai:......

Boss Yu then said: As long as they see the results, it should be easy to understand. Then they will only admire you. Okay, Xiao Shuai Shuai, be happy. It's normal to hit a wall once, as long as you learn a lesson from it.

Although Xiao Shuai Shuai is still a little dissatisfied, he is not as angry as he was at the beginning. Xiao Shuaishuai replied: Okay, let me continue to work on the function first. Let me try the function of synonyms first.

Synonym examples:

  1. XXL,加大,加大码<br />  2. 外套,衣,衣服,外衣,上衣<br />  3. 女款,女士,女生,女性<br /><br /><br />
Copy after login

Considering that a certain category has different definitions for synonyms of some words, Xiaoshuai designed the table structure like this:

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

Xiao Shuai Shuai also added some data.

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

Xiao Shuai Shuai extended a CharListHandle class to specifically handle these synonyms.

The code is as follows:

<?<span>php

</span><span>class</span> LinklistCharListHandle <span>extends</span><span> CharListHandle {
    </span><span>public</span> <span>function</span> <span>exec</span><span>(){
        </span><span>$sql</span> = "select word from category_linklist where cid='<span>$this</span>->selectorItem->cid'"<span>;
        </span><span>$linklist</span> = DB::makeArray(<span>$sql</span><span>);
        </span><span>foreach</span>(<span>$linklist</span> <span>as</span> <span>$strWords</span><span>){
            </span><span>$words</span> = <span>explode</span>(",",<span>$strWords</span><span>);

            </span><span>$properties</span> = <span>$this</span>->selectorItem-><span>getProperties();
            </span><span>foreach</span>(<span>$properties</span> <span>as</span> <span>$property</span><span>){

                </span><span>$this</span>->charlist->addCore(<span>$property</span>-><span>value);
                </span><span>if</span>(<span>in_array</span>(<span>$property</span>->value,<span>$words</span><span>)){
                    </span><span>foreach</span>(<span>$words</span> <span>as</span> <span>$char</span><span>){
                        </span><span>$this</span>->charlist->addCore(<span>$char</span><span>);
                    }
                }
            }
        }
    }
}</span>
Copy after login

Xiao Shuai Shuai has added an interface for SelectorItem to obtain attribute arrays:

<span>class</span><span> SelectorItem {  

       </span><span>#</span><span>......</span>

    <span>public</span> <span>function</span><span> getProperties(){

        </span><span>$result</span> = <span>array</span><span>();
        </span><span>$properties</span> = <span>explode</span>(";",<span>$this</span>->item-><span>props_name);
        </span><span>foreach</span>(<span>$properties</span> <span>as</span> <span>$strProperty</span><span>){
            </span><span>$result</span>[] = self::createItemProperty(<span>explode</span>(":",<span>$strProperty</span><span>));
        }
       </span><span>return</span> <span>$result</span><span>;
    }

    </span><span>public</span> <span>static</span> <span>function</span> createItemProperty(<span>$propertyArr</span><span>){
        </span><span>$property</span> = <span>new</span><span> stdClass();
        </span><span>$property</span>->id = <span>$propertyArr</span>[0<span>];
        </span><span>$property</span>->fieldId = <span>$propertyArr</span>[1<span>];
        </span><span>$property</span>->name = <span>$propertyArr</span>[2<span>];
        </span><span>$property</span>->value = <span>$propertyArr</span>[3<span>];
        </span><span>return</span> <span>$property</span><span>;
    }

   </span><span>#</span><span>......</span>
}
Copy after login

The easy changes to Selector are as follows:

<span>class</span><span> Selector {

    </span><span>private</span> <span>static</span> <span>$charListHandle</span> = <span>array</span><span>(
        </span>"黑名单" => "BacklistCharListHandle",
        "近义词" => "LinklistCharListHandle"<span>
    );

    </span><span>#</span><span>......</span>
}
Copy after login

When Xiao Shuaishuai showed this code to Boss Yu, Boss Yu just took a look at it and approved Xiao Shuaishuai.

Xiao Shuai Shuai is puzzled.

Foretelling why Xiao Shuai Shuai was criticized, please read the breakdown next time.

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/869240.htmlTechArticleTeach you step by step how to do keyword matching projects (search engines) ---- Day 17, teach you how to do it Day 17 Guest appearance on Day 17: Diaosi’s cheating form artifact starting point: teach you step by step the key...
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to adjust aperture on Xiaomi Mi 14 Ultra? How to adjust aperture on Xiaomi Mi 14 Ultra? Mar 19, 2024 am 09:01 AM

Adjusting the aperture size has a crucial impact on the photo effect. Xiaomi Mi 14 Ultra provides unprecedented flexibility in camera aperture adjustment. In order to allow everyone to adjust the aperture smoothly and realize the free adjustment of the aperture size, the editor here brings you a detailed tutorial on how to set the aperture on Xiaomi Mi 14Ultra. How to adjust the aperture on Xiaomi Mi 14Ultra? Start the camera, switch to &quot;Professional Mode&quot;, and select the main camera - W lens. Click on the aperture, open the aperture dial, A is automatic, select f/1.9 or f/4.0 as needed.

Can AI conquer Fermat's last theorem? Mathematician gave up 5 years of his career to turn 100 pages of proof into code Can AI conquer Fermat's last theorem? Mathematician gave up 5 years of his career to turn 100 pages of proof into code Apr 09, 2024 pm 03:20 PM

Fermat's last theorem, about to be conquered by AI? And the most meaningful part of the whole thing is that Fermat’s Last Theorem, which AI is about to solve, is precisely to prove that AI is useless. Once upon a time, mathematics belonged to the realm of pure human intelligence; now, this territory is being deciphered and trampled by advanced algorithms. Image Fermat's Last Theorem is a "notorious" puzzle that has puzzled mathematicians for centuries. It was proven in 1993, and now mathematicians have a big plan: to recreate the proof using computers. They hope that any logical errors in this version of the proof can be checked by a computer. Project address: https://github.com/riccardobrasca/flt

How to set Chinese in Cheat Engine? How to set Chinese in ce modifier How to set Chinese in Cheat Engine? How to set Chinese in ce modifier Mar 18, 2024 pm 01:20 PM

Ce Modifier (CheatEngine) is a game modification tool dedicated to modifying and editing game memory. So how to set Chinese in CheatEngine? Next, the editor will tell you how to set Chinese in Ce Modifier. I hope it can Help friends in need. In the new software we download, it can be confusing to find that the interface is not in Chinese. Even though this software was not developed in China, there are ways to convert it to the Chinese version. This problem can be solved by simply applying the Chinese patch. After downloading and installing the CheatEngine (ce modifier) ​​software, open the installation location and find the folder named languages, as shown in the figure below

How to update Honor MagicOS 8.0 on Honor 90 GT? How to update Honor MagicOS 8.0 on Honor 90 GT? Mar 18, 2024 pm 06:46 PM

Honor 90GT is a cost-effective smartphone with excellent performance and excellent user experience. However, sometimes we may encounter some problems, such as how to update Honor MagicOS8.0 on Honor 90GT? This step may be different for different mobile phones and different models. So, let us discuss how to upgrade the system correctly. How to update Honor MagicOS 8.0 on Honor 90GT? According to news on February 28, Honor today pushed the MagicOS8.0 public beta update for its three mobile phones 90GT/100/100Pro. The package version number is 8.0.0.106 (C00E106R3P1) 1. Ensure your Honor The battery of the 90GT is fully charged;

Teach you how to use the new advanced features of iOS 17.4 'Stolen Device Protection' Teach you how to use the new advanced features of iOS 17.4 'Stolen Device Protection' Mar 10, 2024 pm 04:34 PM

Apple rolled out the iOS 17.4 update on Tuesday, bringing a slew of new features and fixes to iPhones. The update includes new emojis, and EU users will also be able to download them from other app stores. In addition, the update also strengthens the control of iPhone security and introduces more "Stolen Device Protection" setting options to provide users with more choices and protection. "iOS17.3 introduces the "Stolen Device Protection" function for the first time, adding extra security to users' sensitive information. When the user is away from home and other familiar places, this function requires the user to enter biometric information for the first time, and after one hour You must enter information again to access and change certain data, such as changing your Apple ID password or turning off stolen device protection.

Planet Mojo: Building a Web3 game metaverse from the auto-chess game Mojo Melee Planet Mojo: Building a Web3 game metaverse from the auto-chess game Mojo Melee Mar 14, 2024 pm 05:55 PM

Popular Metaverse game projects founded in the last crypto cycle are accelerating their expansion. On March 4, PlanetMojo, the Web3 game metaverse platform, announced a number of important developments in its game ecology, including the announcement of the upcoming parkour game GoGoMojo, the launch of the new season "Way of War" in the flagship auto-chess game MojoMelee, and the celebration of the new The first ETH series "WarBannerNFT" launched this season in cooperation with MagicEden. In addition, PlanetMojo also revealed that they plan to launch Android and iOS mobile versions of MojoMelee later this year. This project will be launched at the end of 2021. After nearly two years of hard work in the bear market, it will soon be completed.

DaVinci Resolve Studio now supports AV1 hardware encoding for AMD graphics cards DaVinci Resolve Studio now supports AV1 hardware encoding for AMD graphics cards Mar 06, 2024 pm 10:04 PM

Recent news, lackMagic has launched the 18.5PublicBeta2 public beta update of the DaVinci Resolve Studio video editing software, bringing AV1 encoding support to AMD Radeon graphics cards. After updating to the latest version, AMD graphics card users will be able to take advantage of hardware acceleration for AV1 encoding in DaVinci Resolve Studio. Although the official does not specify the supported architectures or models, it is expected that all AMD graphics card users can try this feature. In 2018, AOMedia released a new video coding standard AV1 (AOMediaVideoCodec1.0). AV1 is produced by a number of

How to set up Cheat Engine in Chinese? Cheat Engine setting Chinese method How to set up Cheat Engine in Chinese? Cheat Engine setting Chinese method Mar 13, 2024 pm 04:49 PM

CheatEngine is a game editor that can edit and modify the game's memory. However, its default language is non-Chinese, which is inconvenient for many friends. So how to set Chinese in CheatEngine? Today, the editor will give you a detailed introduction to how to set up Chinese in CheatEngine. I hope it can help you. Setting method one: 1. Double-click to open the software and click "edit" in the upper left corner. 2. Then click “settings” in the option list below. 3. In the opened window interface, click "languages" in the left column

See all articles