|
|
如何用PHP&XML编制一个迷你搜索引擎实例? ~ admin
脚本范例被设计为通过PHP的CGI方式的命令行来调用。因此,统计结果输出的格式为文本格式。如果你要将脚本运用到互联网上,那么你需要修改输出函数来产生HTML格式。
如何用PHP&XML编制一个迷你搜索引擎实例?
让我们首先来熟悉一下我们程序中用到的那个XML(保存为xyz.xml)。
<?xml version="1.0" encoding="gb2312" ?> <links>采用PHP和XML技术构建的搜索引擎 <web memo="memo1" url="">name1</web> <sub>电脑网络 <web memo="nemo2">name2</web> <sub>程序设计 <web memo="memo3">name3</web> <sub>PHP <web url="http://www.phpbuilder.com/" memo="[英文]PHP开发资源。"> www.phpbuilder.com</web> <web url="http://www.fokus.gmd.de" memo="[英文]PHP开发手册。 "> PHP Manual</web> </sub> </sub> </sub> </links> | 它的结构相当简单,根元素就是links,sub代表着一个类别,web就是一个网站的信息,其中包含着属性,url代表网站的联接,memo为备注信息,<web>??</web> 、<sub>??</sub>中包含的为元素的数据在这里就是类别和网站的名称,这是符合上面的规定的。
现在我们来回答上面提出的问题:为什么要用XML来编制搜索引擎? 第一个原因就是有时候由于各种原因我们可能不能用到数据库(MySQL或者其他); 其次,对于小数据量的搜索引擎来说,它的数据量很小,如果用数据库来做,效率未必有多高;
最重要的一点是,这个搜索引擎维护起来相当的简单,并且不用编写繁琐的数据库的维护的程序。例如,我们要添加一个类别或者网页,只要编辑文本的文件,加上一福紈eb>???</web>或是<sub>????</sub>就可以了,而且,如果想把一个类别移动到另一个地方的话,我们只要将这一部分的sub复制过去就行了。
下面一个最简单的用PHP显示XML的范例。
下面的程序是将解析XML并按照树形结构输出至浏览器,并显示每层的元素总数。
<?php $file = "demo.xml";// XML文件 function xml_parse_from_file($parser, $file) {// 解析XML文件的函数 } function start_element($parser, $name, $attrs) {//遇到了开元素标记如<a href="link">就执行这一段} function stop_element($parser, $name) function data($parser, $data) function showcount(){ //显示每一层的元素总数}
global $level,$levelcount,$maxlevel; $level = -1; $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); // 释放解析器 showcount(); ?> | 在上面的程序的基础上,可以显示一段子树,我们依照元素的层数和他在该层的第几号来对他进行定位
例如:
links (0,1) +----web (1,1) +----sub (1,2) | +----web (2,1) | +----sub (2,2) | | +----web (3,1) | | +----sub (3,2) : :
|
|