検索エンジン
著者: Sha Yu
編集者注: これは、検索エンジンの原理を詳細に分析するだけでなく、PHP を使用して検索エンジンをコンパイルすることに関する著者自身のアイデアのいくつかも提供する素晴らしいプログラミング教育記事です。記事全体が簡単な言葉で説明されており、専門家も初心者も多くのインスピレーションを得ることができると思います。
ウェブ検索エンジンについて話すとき、ほとんどの人はYahooを思い浮かべます。実際、Yahoo はインターネット検索の時代を築きました。しかし、Yahoo が現在ウェブ検索に使用しているテクノロジーは、同社が元々開発したものではありません。 2000 年 8 月、Yahoo はスタンフォード大学の学生によって設立されたベンチャー企業である Google (www.google.com) のテクノロジーを採用しました。その理由は非常に単純です。Google の検索エンジンは、Yahoo が以前に使用していた技術よりも、より速く、より正確に必要な情報を検索できるからです。
強力で効率的な検索エンジンやデータベースを短期間に自分たちで設計・開発することは、技術的にも資金的にもおそらく不可能ですが、Yahooが他人の技術を使っているのですから、私たちもそれを使うことはできるでしょうか?他の人の既成の検索エンジン Web サイトについてはどうですか?
プログラミングのアイデアの分析
私たちは次のように想像できます: クエリをシミュレートし、対応する形式で検索エンジンの Web サイトに検索コマンドを発行し、検索結果を返し、結果の HTML コードを分析し、冗長な部分を取り除きます。最終的には、必要な形式で当社 Web サイトのページに表示されます。
このように、問題の鍵は、(検索がより意味のあるものになるように) 正確で、(検索結果を分析して表示するのに余分な時間がかかるため) 高速な検索情報を選択する必要があるということです。 、新世代の検索エンジンである Google のさまざまな優れた機能により、検索結果は簡潔 (HTML ソース コードの分析やストリッピングに便利) な検索 Web サイトです。ここでは、PHP を使用してバックグラウンドを実装する方法を確認する例として選択します。 Google (www.google.com) 検索およびフロントエンドのパーソナライズされた表示プロセスの処理。
まず、Google のクエリコマンドの構造を見てみましょう。 www.google.com の Web サイトにアクセスし、クエリ バーに「abcd」と入力してクエリ ボタンをクリックすると、ブラウザのアドレス バーが「http://www.google.com/search?q=」に変わることがわかります。 abcd&btnG=Google %CB%D1%CB%F7&hl=zh-CN&lr= を見ると、Google がクエリ パラメータを渡し、フォームの get メソッドを通じてクエリ コマンドを送信していることがわかります。 PHP の file() 関数を使用して、このクエリ プロセスをシミュレートできます。
File()関数を理解する
構文: array file(string filename);
戻り値は配列であり、すべてのファイルが配列変数に読み込まれます。ここでのファイルはローカルまたはリモートにすることができ、リモート ファイルは使用されるプロトコルを示す必要があります。例: result=file(“http://www.google.com/search?q=abcd&btnG=Google%CB%D1%CB%F7&hl=zh-CN&lr=”)、このステートメントは、単語のクエリをシミュレートします。 Google の「abcd」処理により、検索結果が各行の要素の形式で配列変数の結果に返されます。ここで読み取られるファイルはリモートであるため、プロトコル名「http://」が欠落することはできません。
任意の検索でユーザーに検索文字を入力してもらいたい場合は、入力テキスト ボックスと送信ボタンを作成し、上記の検索文字「abcd」を変数に置き換えます。
echo '
最後から 2 番目の
タグの間に含まれていることを見つけるのは難しくありません。この機能を使用すると、このように Google のヘッダーとフッターを削除できます。
以下のすべての手順は、上記の手順の「さらなる処理」セクションで継続されます。
result_string = strstr( result_string, "
"); //最初の
から始まる result_string 以降の文字列を取得します
position= strpos( result_string,"
result_string=substr(result_string,0,position);//最初の
tableシンボルの前の文字列をインターセプトして脚注を削除します
アプリケーションと実装
OK、これで便利なHTML ソース コードで、残りの問題は、このコンテンツを自律的に表示する方法です。これらの検索結果エントリを分析すると、各エントリも
で区切られていることがわかります。つまり、この特徴に従って、各エントリが段落に分割されています。各項目を分割するには、explode() 関数を使用します:
構文:explode(string separator, string string);
配列を返し、セパレータで分割されたそれぞれの小さな文字列が配列に保存されます:
result_array =explode("
", result_string); //文字列 "
" を使用して結果を切り取ります
各要素が検索結果の項目である配列を取得します。次に、各項目とその HTML 表示形式コードを調べて、必要に応じて置き換えます。次に、ループを使用して、result_array 内の各項目を処理します。エントリ
}
各エントリについて、いくつかの特徴も簡単に見つけることができます。各エントリはタイトル、要約、紹介、カテゴリ、URL などで構成されており、各部分は改行されています。つまり、
every_item=explode("
", result_array[ i]); このようにして、配列every_itemを取得します。 Every_item[0] はタイトル、every_item[1] と Every_item[2] は 2 行の概要です。ただし、every_item[3] と Every_item[4] などのヘッダーに「"、"< font size=-1 color=#6f6f6f>カテゴリ:< /font>" の文字は紹介またはカテゴリです (一部の結果エントリにはこの項目がないため)、 if ヘッダーに「< font color=green>」が含まれている場合、それは URL である必要があります。このような比較には正規表現を使用することがよくあります (省略)。$ などを置き換える場合にも非常に便利です。タイトルを含むevery_item[0] 自体にリンクがあります。リンクを新しいウィンドウで開くようにリンク属性を変更します。
echo eregi_replace(' {
... // 各エントリを処理して削除します。最初の項目 (最初の項目はタイトルで、すでに表示されています) each item
... //その他の形式の変更
}
これによりリンク属性が変更され、その他の多くの表示形式の変更、削除、置換は次を使用して完了できます。定期的な置き換え eregi_replace()。
この時点で、各検索項目の各項目を取得できており、各項目の形式を自由に変更したり、美しい表を載せたりすることもできます。ただし、優れたプログラムはさまざまな動作環境に適応できる必要があり、ここでも例外ではありません。実際、これを完全に実行するには、HTML の検索結果を除去するためのフレームワーク方法についてのみ説明しました。検索結果の総数やページ数などを表示します。また、「カテゴリ」や「紹介文」などのGoogle関連のコードを削除して、元のWebサイトを閲覧できないようにすることもできます。全て。ただし、HTML を解析することで、これらのコンテンツと要件を抽出することができます。今では誰もが自分で行うことができ、高度にパーソナライズされた検索エンジンを構築できます。