백엔드 개발 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 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

여러 조건을 판단하기 위해 C 언어로 작성하는 방법 여러 조건을 판단하기 위해 C 언어로 작성하는 방법 Mar 25, 2024 pm 03:24 PM

C 언어에서 if 문은 일반적으로 단일 조건에 따라 특정 코드 블록을 실행하는 데 사용됩니다. 그러나 여러 조건을 결합하여 &&, || 및 !와 같은 논리 연산자를 사용하여 결정을 내릴 수 있습니다. 여러 조건을 판단하기 위해 논리적 AND(&&)를 사용하고, 하나 이상의 조건을 판단하기 위해 논리적 OR(||)를 사용하고, 단일 조건의 부정을 판단하기 위해 논리적 NOT(!)을 사용하고, if 문을 중첩하고 괄호를 사용하는 것을 포함합니다. 우선순위를 명확히 하기 위해.

Baidu 클라우드 디스크 검색 엔진 입구 Baidu 클라우드 디스크 검색 엔진 입구 Feb 27, 2024 pm 01:00 PM

Baidu Cloud는 사용자가 많은 파일을 저장할 수 있는 소프트웨어입니다. 그러면 Baidu Cloud Disk 검색 엔진의 입구는 무엇입니까? 사용자는 URL https://pan.baidu.com을 입력하여 Baidu Cloud Disk에 들어갈 수 있습니다. Baidu Cloud Disk 검색 엔진에 대한 자세한 소개는 다음과 같습니다. . Baidu 클라우드 디스크 검색 엔진 입구 1. Qianfan 검색 웹사이트: https://pan.qianfan.app 지원 네트워크 디스크: 집계 검색, Alibaba, Baidu, Quark, Lanzuo, Tianyi, Xunlei 네트워크 디스크 보기 방법: 로그인 필요, 회사 팔로우 활성화 코드 획득의 장점: 네트워크 디스크는 포괄적이고 리소스가 많으며 인터페이스가 간단합니다. 2. Maolipansou 웹사이트: alipansou.c

iPhone 및 iPad에서 검색 엔진을 변경하는 방법 iPhone 및 iPad에서 검색 엔진을 변경하는 방법 Apr 25, 2023 am 08:28 AM

iPhone이나 iPad의 Safari, Google Chrome 또는 기타 브라우저에서 검색 엔진을 쉽게 변경할 수 있습니다. 이 튜토리얼에서는 iPhone 및 iPad에서 사용할 수 있는 네 가지 웹 브라우저에서 이를 수행하는 방법을 보여줍니다. iPhone 또는 iPad에서 Safari 검색 엔진을 변경하는 방법 Safari는 iOS 및 iPadOS의 기본 웹 브라우저이지만 검색 엔진이 마음에 들지 않을 수 있습니다. 다행히 다음 단계에 따라 변경할 수 있습니다. iPhone 또는 iPad의 홈 화면에서 설정을 실행하세요. 아래로 스와이프하여 목록에서 Safari를 탭하세요. 다음 메뉴에서는

Java 개발: 검색 엔진 및 전체 텍스트 검색 기능을 구현하는 방법 Java 개발: 검색 엔진 및 전체 텍스트 검색 기능을 구현하는 방법 Sep 21, 2023 pm 01:10 PM

Java 개발: 검색 엔진 및 전체 텍스트 검색 기능을 구현하는 방법, 특정 코드 예제가 필요합니다. 검색 엔진 및 전체 텍스트 검색은 현대 인터넷 시대에 중요한 기능입니다. 사용자가 원하는 것을 빠르게 찾을 수 있도록 도울 뿐만 아니라 웹사이트와 앱에 대한 더 나은 사용자 경험을 제공합니다. 이 기사에서는 Java를 사용하여 검색 엔진 및 전체 텍스트 검색 기능을 개발하는 방법을 소개하고 몇 가지 구체적인 코드 예제를 제공합니다. Lucene 라이브러리를 사용한 전체 텍스트 검색 Lucene은 ApacheSo에서 개발한 오픈 소스 전체 텍스트 검색 엔진 라이브러리입니다.

기술 세계를 탐험할 수 있도록 Go 언어 오픈 소스 프로젝트 5개를 선택했습니다. 기술 세계를 탐험할 수 있도록 Go 언어 오픈 소스 프로젝트 5개를 선택했습니다. Jan 30, 2024 am 09:08 AM

오늘날 급속한 기술 발전의 시대에 프로그래밍 언어는 비가 내린 뒤 버섯처럼 솟아오르고 있습니다. 많은 주목을 받고 있는 언어 중 하나가 바로 Go 언어인데, 단순성, 효율성, 동시성 안전성 등 다양한 기능으로 많은 개발자들에게 사랑을 받고 있습니다. Go 언어는 뛰어난 오픈 소스 프로젝트가 많이 포함된 강력한 생태계로 유명합니다. 이 기사에서는 선택된 Go 언어 오픈 소스 프로젝트 5개를 소개하고 독자가 Go 언어 오픈 소스 프로젝트의 세계를 탐색하도록 안내합니다. KubernetesKubernetes는 자동화를 위한 오픈 소스 컨테이너 오케스트레이션 엔진입니다.

Go 언어 개발 필수 사항: 인기 있는 프레임워크 권장 사항 5가지 Go 언어 개발 필수 사항: 인기 있는 프레임워크 권장 사항 5가지 Mar 24, 2024 pm 01:15 PM

"Go 언어 개발 필수 사항: 5가지 인기 프레임워크 권장 사항" 빠르고 효율적인 프로그래밍 언어인 Go 언어는 점점 더 많은 개발자들이 선호하고 있습니다. 개발 효율성을 높이고 코드 구조를 최적화하기 위해 많은 개발자는 프레임워크를 사용하여 애플리케이션을 빠르게 구축하는 방법을 선택합니다. Go 언어의 세계에는 선택할 수 있는 훌륭한 프레임워크가 많이 있습니다. 이 기사에서는 인기 있는 Go 언어 프레임워크 5개를 소개하고 독자가 이러한 프레임워크를 더 잘 이해하고 사용할 수 있도록 구체적인 코드 예제를 제공합니다. 1.GinGin은 빠른 속도를 갖춘 경량 웹 프레임워크입니다.

Google 크롬 검색 엔진을 사용하는 방법 Google 크롬 검색 엔진을 사용하는 방법 Jan 04, 2024 am 11:15 AM

Chrome은 매우 훌륭합니다. 많은 친구들이 Google의 자체 검색 엔진을 사용하고 싶지만 사용 방법을 모릅니다. Google Chrome에서 Google 검색 엔진을 사용하는 방법: 1. Google Chrome을 열고 오른쪽 상단에 있는 더보기를 클릭하여 설정을 엽니다. 2. 설정 입력 후 좌측의 '검색엔진'을 클릭하세요. 3. 검색엔진이 'Google'인지 확인하세요. 4. 그렇지 않은 경우 드롭다운 버튼을 클릭하여 'Google'로 변경할 수 있습니다.

인공지능 검색 분야에서는 구글과 마이크로소프트가 경쟁한다. 인공지능 검색 분야에서는 구글과 마이크로소프트가 경쟁한다. Apr 08, 2023 am 11:31 AM

ChatGPT는 작년 말 출시된 이후 전통적인 정보 검색 방식에 대한 주요 위협으로 여겨져 왔습니다. 다양하기 때문에 사람들의 질문에 답할 수도 있고, 에세이나 시를 쓸 수도 있고, 프로그램 코드를 작성할 수도 있습니다. 일관된 답변을 제공하는 대화형 AI의 능력은 수십 년 동안 사람들이 인터넷에서 정보를 검색하는 벤치마크 플랫폼이었던 Google 검색 엔진에 대한 위협으로 간주됩니다. OpenAI의 ChatGPT는 사용자가 묻는 특정 질문에 대한 답변을 맞춤화하여 웹사이트 탐색 시간을 절약할 수 있습니다. 지난 12월 The New York Times가 발표한 보고서에 따르면 ChatGPT의 하룻밤 성공으로 인해 Google은 이를 "코드 레드"라고 부르고 인공 지능 챗봇이 검색 엔진 비즈니스에 가하는 위협을 해결하기 시작했습니다. ~에 따르면

See all articles