首頁 後端開發 php教程 用PHP&XML编制迷你搜索引擎(四)_PHP

用PHP&XML编制迷你搜索引擎(四)_PHP

Jun 01, 2016 pm 12:35 PM
echo if Level 搜尋引擎 迷你

[程序实例 ] 用PHP&XML编制迷你搜索引擎 

作者    来源   

时间   2000年11月30日  阅读次数   247 

版本  
-----  价值   17 

    
[投他一票] 

来源
奥索网



用PHP
&XML编制迷你搜索引擎



五、mini的搜索引擎

作了如干的铺垫
令人激动的时刻到来了。

分页等版式输出和用SQL的搜索引擎差不多
我就不加注释了。

第一段为仿sina
yahoo的按照类别查询

第二段为搜索查询部分
(其实就是把整个树遍历一遍)显示符合的

内容。



说明


"网络狂飙之谜你搜索引擎"适用于小数据量的数据索引查询根据测试当数据量超过1000条以后便不再适用相当浪费主机资源建议您超过400条记录采用mysql等数据库语言构建。希望您通过我的程序对PHP对XML的解析函数有所认识。所有范例程序欢迎大家适用如果您要将其用于自己的主页中请于我联系说明其实就是将其用于的网站的名称告知于我

sfs
(sfsz@chinese.com)



以上的所有范例请到我的主页fire
.oso.com.cn

上下载
我学PHP不到一个月也刚来oso希望文章中的错误之处大家能谅解。以后我将为大家奉献出更多的源创范例。



废话少说
尽请看来。

__________________________________________________________



xml2
.php



html>

body>

style type=text/css>

td
,p,li,input,select {font-size:12px;}

A
:link {font-size:12px;color:#00007f;}

A
:visited {font-size:12px;color:#00007f;}

A
:active {font-size:12px;color:#ff0000;}

A
:hover {font-size:12px;color:#ff0000;}

.title {font-family:Tahoma; width=420 ;font-size :16px; font-weight :bold; color :steelblue; filter:Shadow(color="LightGrey", Direction="130");}

.counter{font-family:Tahoma; color=green; font-size : 12px;}

/style>



// XML文件

$file = "demo.xml";

$pagecount = 10;



class Cweb { //网页

var $name;

var $url;

var $memo;

}



class Cwebs {

var $items = array(Cweb);

var $count = 0;

}



class Csub { //类别

var $name;

var $url;

}



class Csubs {

var $items = array(Csub);

var $count = 0;

}



function xml_parse_from_file($parser, $file)

{

if(!file_exists($file))

die("Can’t find file "$file".");





if(!($fp = @fopen($file, "r")))

die("Can’t open file "$file".");



while($data = fread($fp, 4096)) {

if(!xml_parse($parser, $data, feof($fp)))

return(false);

}



fclose($fp);

return(true);

}







function start_element($parser, $name, $attrs)

{

global $show,$level,$levelcount,$maxlevel,$hide,$lev,$num,$PHP_SELF;

global $webs,$subs;

$level += 1;

if($level>$maxlevel)$maxlevel=$level;

$levelcount[$level]+=1;



if($hide){

if($level==$lev&&$levelcount[$level]==$num)$hide=FALSE;

}else{

if($level
}





if(!$hide){

switch($name){

case "sub":

$show="sub";

break;

case "web":

$show="web";

break;

default:



break;

}



if($level==$lev+1&&$level>0){



switch($show){

case "sub":

$subs->count+=1;

$subs->items[$subs->count]->url = "$PHP_SELF?lev=$level&num=$levelcount[$level]";

break;

case "web":

$webs->count+=1;

while ( list( $key, $val ) = each( $attrs ) ) {

switch(trim($key)){

case "url" :

$webs->items[$webs->count]->url=trim($val);

break;

case "memo" :

$webs->items[$webs->count]->memo=trim($val);

break;



}

}

break;

default:



break;

}

}





}





}



function stop_element($parser, $name)

{

global $level;



$level -= 1;

}



function data($parser, $data)

{

global $level,$hide,$show,$lev,$levelcount,$num;

global $webs,$subs,$title;

if($level==$lev&&$levelcount[$level]==$num&&trim($data)!="")$title=trim($data);

if(!$hide)

if(trim($data)!=""&&($level==$lev+1&&$level>0)){

switch($show){

case "sub":

$subs->items[$subs->count]->name=trim($data);

break;

case "web":

$webs->items[$webs->count]->name=trim($data);

break;

}

}

}





//main start

global $lev,$num,$PHP_SELF;

global $title,$webs,$subs;

$level = -1;

$hide = TRUE;

$webs = new Cwebs;

$subs = new Csubs;



if($lev==""){$lev=0;$num=1;}

if($page=="")$page=0;



$parser = xml_parser_create();



xml_set_element_handler($parser, "start_element", "stop_element");

xml_set_character_data_handler($parser, "data");

xml_parser_set_option($parser, XML_OPTION_CASE_FOLDING, 0);



$ret = xml_parse_from_file($parser, $file);

if(!$ret)

{

die(sprintf("XML error: %s at line %d",

xml_error_string(xml_get_error_code($parser)),

xml_get_current_line_number($parser)));

}



xml_parser_free($parser);





echo "

搜索首页 ";

echo "后退

".

"
";

echo "
".$title."
";

$i=0;

echo "";

while($icount){

$i+=1;

if(($i%5)==1)echo"";

echo "";

}

echo "
";

echo "".$subs->items[$i]->name."";

echo "

";



$i=$page*$pagecount;

if ($webs->count > 0){

echo "
".($page+1)."/";

echo Ceil($webs->count/$pagecount);}

echo "";

while($icount&&$i
$i+=1;

echo "";

echo "";

}

echo "
".$i." ".

$webs->items[$i]->name."
".$webs->items[$i]->memo;

echo "
";

if ($webs->count > 0){

if($page>0)echo "上一页 ";

if(($page+1)count/$pagecount))echo "下一页";

}

?>

/body>

/html>



__________________________________________________________

xml3
.php

关键字匹配采用eregi函数
功能相对简单且有些bug

如输入C
++会报错因为+是关键字这点就不如用SQL查询了。

您可以在下面的程序的基础上加以完善
我这个迷你的就

起到抛砖引玉的作用吧。



html>

body>

style type=text/css>

td
,p,li,input,select {font-size:12px;}

A
:link {font-size:12px;color:#00007f;}

A
:visited {font-size:12px;color:#00007f;}

A
:active {font-size:12px;color:#ff0000;}

A
:hover {font-size:12px;color:#ff0000;}

.title {font-family:Tahoma; width=420 ;font-size :16px; font-weight :bold; color :steelblue; filter:Shadow(color="LightGrey", Direction="130");}

.counter{font-family:Tahoma; color=green; font-size : 12px;}

/style>



// XML文件

$file = "demo.xml";

$pagecount = 10;



class Cweb { //网页

var $name;

var $url;

var $memo;

}



class Cwebs {

var $items = array(Cweb);

var $count = 0;

}



class Csub { //类别

var $name;

var $url;

}



class Csubs {

var $items = array(Csub);

var $count = 0;

}



// 解析XML文件的函数

function xml_parse_from_file($parser, $file)

{

if(!file_exists($file))

die("Can’t find file "$file".");





if(!($fp = @fopen($file, "r")))

die("Can’t open file "$file".");



while($data = fread($fp, 4096)) {

if(!xml_parse($parser, $data, feof($fp)))

return(false);

}



fclose($fp);

return(true);

}







function start_element($parser, $name, $attrs)

{

global $show,$level,$levelcount,$maxlevel,$PHP_SELF;

global $webs,$subs;

global $search,$finded;

$finded=FALSE;

$level += 1;

if($level>$maxlevel)$maxlevel=$level;

$levelcount[$level]+=1;



switch($name){

case "sub":

$show="sub";

break;

case "web":

$show="web";

break;

default:



break;

}



switch($show){

case "sub":

$subs->count+=1;

$subs->items[$subs->count]->url = "xml2.php?lev=$level&num=$levelcount[$level]";

break;

case "web":

$webs->count+=1;

while ( list( $key, $val ) = each( $attrs ) ) {

if(eregi($search,$val))$finded=TRUE;



switch(trim($key)){

case "url" :

$webs->items[$webs->count]->url=trim($val);

break;

case "memo" :

$webs->items[$webs->count]->memo=trim($val);

break;

}

}

break;

default:



break;

}



}



function stop_element($parser, $name)

{

global $level;



$level -= 1;

}



function data($parser, $data)

{

global $level,$show,$levelcount;

global $webs,$subs;

global $search,$finded;



if(trim($data)!=""){

switch($show){

case "sub":

$subs->items[$subs->count]->name=trim($data);

if(!eregi($search,$data))$subs->count-=1;

break;

case "web":

$webs->items[$webs->count]->name=trim($data);

if((!eregi($search,$data))&&(!$finded))$webs->count-=1;

break;

}

}

}





//main start

global $PHP_SELF;

global $search,$webs,$subs;

$level = -1;

$hide = TRUE;

$webs = new Cwebs;

$subs = new Csubs;



if($page=="")$page=0;

if($search=="")$search="请输入关键字";



$parser = xml_parser_create();



xml_set_element_handler($parser, "start_element", "stop_element");

xml_set_character_data_handler($parser, "data");

xml_parser_set_option($parser, XML_OPTION_CASE_FOLDING, 0);



$ret = xml_parse_from_file($parser, $file);

if(!$ret)

{

die(sprintf("XML error: %s at line %d",

xml_error_string(xml_get_error_code($parser)),

xml_get_current_line_number($parser)));

}



xml_parser_free($parser);



// 输出



echo "

搜索首页 ";

echo "后退

";

echo "
".$search."
";

$i=0;

echo "";

while($icount){

$i+=1;

if(($i%5)==1)echo"";

echo "";

}

echo "
";

echo "".$subs->items[$i]->name."";

echo "

";



$i=$page*$pagecount;

if ($webs->count > 0){

echo "
".($page+1)."/";

echo Ceil($webs->count/$pagecount);}

echo "";

while($icount&&$i
$i+=1;

echo "";

echo "";

}

echo "
".$i." ".

$webs->items[$i]->name."
".$webs->items[$i]->memo;

echo "
";

if ($webs->count > 0){

if($page>0)echo "上一页 ";

if(($page+1)count/$pagecount))echo "下一页";

}

?>

/body>

/html>
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1675
14
CakePHP 教程
1429
52
Laravel 教程
1333
25
PHP教程
1278
29
C# 教程
1257
24
c語言if判斷多個條件怎麼寫 c語言if判斷多個條件怎麼寫 Mar 25, 2024 pm 03:24 PM

在C語言中,if語句通常用於基於單一條件執行特定程式碼區塊。但是,透過使用邏輯運算子(如 &amp;&amp;、|| 和 !),可以組合多個條件來進行判斷。包括使用邏輯與(&amp;&amp;)判斷多個條件、使用邏輯或(||)判斷至少一個條件、使用邏輯非(!)判斷單一條件的否定,以及嵌套if語句和使用括號明確優先權。

如何在 iPhone 和 iPad 上更改搜尋引擎 如何在 iPhone 和 iPad 上更改搜尋引擎 Apr 25, 2023 am 08:28 AM

在iPhone或iPad上的Safari、GoogleChrome或其他瀏覽器中更改搜尋引擎非常簡單。本教學將向您展示如何在iPhone和iPad上可用的四種不同網頁瀏覽器上進行操作。如何更改iPhone或iPad上的Safari搜尋引擎Safari是iOS和iPadOS上的預設網路瀏覽器,但您可能不喜歡這個搜尋引擎。幸運的是,您可以使用以下步驟進行更改:在iPhone或iPad上,從主畫面啟動設定。向下滑動並從清單中點按Safari。在下一個選單中,

百度雲端硬碟搜尋引擎入口 百度雲端硬碟搜尋引擎入口 Feb 27, 2024 pm 01:00 PM

百度雲是能夠讓使用者存放很多文件的軟體,那麼百度雲端硬碟搜尋引擎入口是什麼呢?使用者可以輸入https://pan.baidu.com這個網址就能夠進入百度雲盤,這篇百度雲盤搜尋引擎最新入口分享就能夠告訴大家具體的介紹,以下就是詳細的介紹,趕緊看看吧。百度雲盤搜尋引擎入口1、千帆搜尋網址:https://pan.qianfan.app支援網盤:聚合搜索,阿里、百度、夸克、藍奏、天翼、迅雷網盤查看方式:需登入、關注公號獲取啟動碼優點:網盤很全,資源很多,介面簡單。 2、貓狸盤搜尋網址:alipansou.c

Java開發:如何實作搜尋引擎和全文檢索功能 Java開發:如何實作搜尋引擎和全文檢索功能 Sep 21, 2023 pm 01:10 PM

Java開發:如何實現搜尋引擎和全文檢索功能,需要具體程式碼範例搜尋引擎和全文檢索是現代網路時代的重要功能。它們不僅可以幫助用戶快速找到想要的內容,還可以為網站和應用程式提供更好的用戶體驗。本文將介紹如何使用Java開發搜尋引擎和全文檢索功能,並提供一些具體的程式碼範例。使用Lucene函式庫實作全文檢索Lucene是一款開源的全文檢索引擎函式庫,由ApacheSo

PHP搜尋引擎效能優化:Algolia的妙用之道 PHP搜尋引擎效能優化:Algolia的妙用之道 Jul 23, 2023 pm 04:21 PM

PHP搜尋引擎效能優化:Algolia的妙用之道隨著網路的發展和使用者對搜尋體驗的要求不斷提高,搜尋引擎的效能優化變得至關重要。在PHP開發領域,Algolia是一個強大且易於整合的搜尋引擎服務。本文將介紹Algolia的妙用之道以及如何透過Algolia來優化PHP搜尋引擎的效能。 Algolia介紹Algolia是一家基於SaaS模式的搜尋引擎服務供應商,

人工智慧搜尋領域,Google微軟展開對抗 人工智慧搜尋領域,Google微軟展開對抗 Apr 08, 2023 am 11:31 AM

自去年年底推出以來,ChatGPT被視為對傳統搜尋資訊方式的重大威脅。因為它是多樣化的,可以回答人們的問題,寫論文或詩歌,甚至編寫程式碼。對話式人工智慧提供連貫答案的能力被認為是對Google搜尋引擎的威脅,幾十年來,谷歌一直是人們在網路上搜尋資訊的標竿平台。 OpenAI的ChatGPT可以客製化使用者提出的特定問題的答案,這可以節省瀏覽網站的時間。 《紐約時報》12月發布的一份報告顯示,ChatGPT一夜之間的成功迫使谷歌稱其為“紅色代碼”,並開始應對人工智慧聊天機器人對其搜尋引擎業務造成的威脅。根據

五個精選的Go語言開源項目,帶你探索科技世界 五個精選的Go語言開源項目,帶你探索科技世界 Jan 30, 2024 am 09:08 AM

在現今科技快速發展的時代,程式語言也如雨後春筍般湧現。其中一門備受矚目的語言就是Go語言,它以其簡潔、高效、並發安全等特性受到了許多開發者的喜愛。 Go語言以其強大的生態系統而著稱,其中有許多優秀的開源專案。本文將介紹五個精選的Go語言開源項目,帶領讀者一起探索Go語言開源專案的世界。 KubernetesKubernetes是一個開源的容器編排引擎,用於自

如何在PHP7.0實現一個全文搜尋引擎? 如何在PHP7.0實現一個全文搜尋引擎? May 26, 2023 pm 04:51 PM

隨著資訊時代的不斷發展,人們越來越依賴網路來獲取資訊。而作為資訊分享的平台之一,網頁搜尋引擎也不斷進化、完善。本文將介紹如何在PHP7.0實現一個全文搜尋引擎,幫助讀者更好地利用PHP技術,快速建立高效率的搜尋引擎。一、全文搜尋引擎概述全文搜尋即使用關鍵字或短語在整篇文件中進行搜索,以找到最匹配的結果。全文搜尋引擎使用演算法對文件進行索引,以加速搜尋。在

See all articles