PHP XML
PHP解析XML 常用的四种方法:
1.XML Expat Parse
2.SimpleXML
3.XMLReader
4.DomDocument
其实用哪个都可以 关键是你觉得顺手,当然他们有一些差别 还有的需要相应版本的库支持 但其功能都能完成大家的需求
目前有两种类型的XML解析器:基于树的解析器 和基于事件的解析器
相对而言,我更喜欢基于事件的解析器,原因在于基于事件的解析器目的集中在XML文档的内容,而不是他们的结果。正因如此,基于事件的解析器能够比基于树的解析器更况的访问数据
XML文件的常识知识:每个标准的XML文件都有一个与它关联的文档类型声明(DTD)或者内嵌的DTD。
这两种类型的解析不同用法:
基于事件的解析器:
Expat 是不检查有效性的解析器,忽略任何 DTD。
作为一款基于事件、非验证的 XML 解析器,Expat 快速且轻巧,十分适合 PHP 的 web 应用程序。
<?php
$data="<?xml version=\"1.0\" encoding=\"ISO-8859-1\"?>
<note>
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don't forget the meeting!</body>
</note>";
//Initialize the XML parser
$parser=xml_parser_create();
//Function to use at the start of an element
function start($parser,$element_name,$element_attrs)
{
switch($element_name)
{
case "NOTE":
echo "-- Note --<br />";
break;
case "TO":
echo "To: ";
break;
case "FROM":
echo "From: ";
break;
case "HEADING":
echo "Heading: ";
break;
case "BODY":
echo "Message: ";
}
}
//Function to use at the end of an element
function stop($parser,$element_name)
{
echo "<br />";
}
//Function to use when finding character data
function char($parser,$data)
{
echo $data;
}
//Specify element handler
xml_set_element_handler($parser,"start","stop");
//Specify data handler
xml_set_character_data_handler($parser,"char");
// //Open XML file :file
// $fp=fopen("test.xml","r");
// //Read data
// while ($data=fread($fp,4096))
while ($data)
{
xml_parse($parser,$data,feof($fp)) or
die (sprintf("XML Error: %s at line %d",
xml_error_string(xml_get_error_code($parser)),
xml_get_current_line_number($parser)));
}
//Free the XML parser
xml_parser_free($parser);
?>
工作原理解释:
通过 xml_parser_create() 函数初始化 XML 解析器
创建配合不同事件处理程序的的函数
添加 xml_set_element_handler() 函数来定义,当解析器遇到开始和结束标签时执行哪个函数
添加 xml_set_character_data_handler() 函数来定义,当解析器遇到字符数据时执行哪个函数
通过 xml_parse() 函数来解析文件 "test.xml"
万一有错误的话,添加 xml_error_string() 函数把 XML 错误转换为文本说明
调用 xml_parser_free() 函数来释放分配给 xml_parser_create() 函数的内存
基于树的解析器
XML DOM 内建的DOM解析器在PHP种处理XML文档成为可能
什么是DOM
DOM提供了针对HTML和XML文档的标准对象集,以及用于访问和操作这些文档的标准接口。
DOM 被分为不同的部分 (Core, XML 和 HTML) 和不同的级别 (DOM Level 1/2/3):
Core DOM - 为任何结构化文档定义标准的对象集
XML DOM - 为 XML 文档定义标准的对象集
HTML DOM - 为 HTML 文档定义标准的对象集
DOM 解析器是基于树的解析器。
请看下面的 XML 文档片段:
<?xml version="1.0" encoding="ISO-8859-1"?>
<from>John</from>
XML DOM 把XML视为一个树结构
Level 1: XML 文档
Level 2: 根元素: <from>
Level 3: 文本元素: "John"
例子
note.xml:
<?xml version="1.0" encoding="ISO-8859-1"?>
<note>
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don't forget the meeting!</body>
</note>
<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("note.xml");
print $xmlDoc->saveXML();
?>
输出的结果为:
George John Reminder Don't forget the meeting!
代码解析:
上面的例子创建了一个 DOMDocument-Object,并把 "note.xml" 中的 XML 载入这个文档对象中。
saveXML() 函数把内部 XML 文档放入一个字符串,这样我们就可以输出它。
循环 XML
<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("note.xml");
$x = $xmlDoc->documentElement;
foreach ($x->childNodes AS $item)
{
print $item->nodeName . " = " . $item->nodeValue . "<br />";
}
?>
以上代码的输出:
#text =
to = George
#text =
from = John
#text =
heading = Reminder
#text =
body = Don't forget the meeting!
#text =
在上面的例子中,您看到了每个元素之间存在空的文本节点。
当 XML 生成时,它通常会在节点之间包含空白。XML DOM 解析器把它们当作普通的元素,如果您不注意它们,有时会产生问题。
PHP SimpleXML
什么是 SimpleXML?
Simple是PHP5的新特性
与DOM 或Expat 解析器相比,SimpleXML仅仅用几行代码就可以从元素读取文本数据
SimpleXML 可把XML文档转换成对象,比如:
元素-被转换为impleXMLElement 对象的单一属性.当同一级别上存在多个元素时,他们会被置于数组中。
属性-通过使用关联数组进行访问,其中的下表对应属性名称,
元素数据-来自元素的文本数据被转换为字符串,如果一个元素拥有多个文本节点,则按照他们被找到的顺序进行排列。
当执行蕾丝下列的基础任务的时候,SimpleXML使用起来非常快捷:
读取XML文件
从XML字符串中提取数据
编辑文本节点或属性
不过,在处理高级XML,比如命名空间,最好使用Expat解析器或者XML DOM。
使用SimpleXML
<?xml version="1.0" encoding="ISO-8859-1"?>
<note>
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don't forget the meeting!</body>
</note>
我门打算从上面的XML文件中输出元素名和数据
需要做:
1 加载XML文件
2 取得第一个元素的名称
3 使用children()函数创建在每个子节点上出发的循环
4 输出每个子节点的元素名称和数据
<?php
$xml = simplexml_load_file("test.xml");
echo $xml->getName() . "<br />";
foreach($xml->children() as $child)
{
echo $child->getName() . ": " . $child . "<br />";
}
?>
以上代码的输出:
note
to: George
from: John
heading: Reminder
body: Don't forget the meeting!