PHP XML DOM

一、XML
Expat解析器

内置的DOM解析器可以处理XML文档在PHP 。  

内建的Expat解析器使在PHP中处理XML文档成为可能。

这里是什么?
的W3C
DOM提供了一套标准的对象为HTML和XML文件,以及一个标准的接口用于访问和操纵它们。

XML用于描述数据,其焦点是数据是什么。XML 文件描述了数据的结构。

的W3C DOM分为不同部分(核心, XML和HTML )和不同层次( 1/2/3级的DOM )

在XML中,没有预定义的标签。您必须定义自己的标签。

*核心的DOM 定义一套标准的对象结构的任何文件
*的XML的DOM 定义一套标准的对象的X ML文件
*的HTML的DOM 定义一套标准的对象为H TML文件

如需读取和更新 – 创建并处理 – 一个XML文档,您需要XML解析器。

如果您想了解更多有关的XML的DOM ,请访问我们的XML的DOM教程。  

两种基本的XML解析器类型:
1.基于树的解析器:这种解析器把XML文档转换为树型结构。它分析整篇文档,并提供了API来访问树种的元素,例如文档对象模型(DOM)。
2.基于事件的解析器:将XML文档视为一系列的事件。当某个具体的事件发生时,解析器会调用函数来处理。

XML解析
要阅读和更新创建和操纵一个XM L文件,您需要一个XM L解析器。

Expat解析器是基于事件的解析器。

有两个基本类型的XML解析器:

基于事件的解析器集中在XML文档的内容,而不是它们的结果。正因如此,基于事件的解析器能够比基于树的解析器更快地访问数据。

树为基础的剖析:这分析器转换XML文件成一个树状结构。分析了整个文件,并提供进入树要素
基于事件的剖析:观XML文件的一系列活动。当某一特定事件发生时,它要求一个函数来处理它
在DOM解析器是一个树为基础的剖析。

请看下面的 XML 片段:
<from>John</from>
基于事件的解析器把上面的 XML 报告为一连串的三个事件:
开始元素:from
开始 CDATA 部分, 值:John
关闭元素: from

看看下面的XML文件部分:

上面的 XML 范例包含了形式良好的 XML。不过这个例子是无效的
XML,因为没有与它关联的文档类型声明 (DTD),也没有内嵌的 DTD。
不过,在使用 Expat 解析器时,这没有区别。Expat
是不检查有效性的解析器,忽略任何 DTD。
作为一款基于事件、非验证的 XML 解析器,Expat 快速且轻巧,十分适合 PHP 的
web 应用程序。
注释:XML 文档必须形式良好,否则 Expat 会生成错误。

<?xml version="1.0" encoding="ISO88591"?>
<from>Jani</from>

The XML DOM sees the XML above as a tree structure:

XML Expat 解析器是PHP核心的组成部分。无需安装就可以使用这些函数。

  • Level 1: XML Document
  • Level 2: Root element: <from>
  • Level 3: Text element: “Jani”

XML文件
将在我们的例子中使用下面的 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>

安装
的DOM XML解析器职能是PHP核心的一部分。没有安装即可使用这些功能。

初始化XML解析器
我们要在PHP中初始化XML解析器,为不同的XML事件定义处理器,然后解析这个XML
文件。

一个XML文件
XML档案下文将用于在我们的例子:

<?php

//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
$fp=fopen("test.xml","r");

//Read data
while ($data=fread($fp,4096))
  {
  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 version="1.0" encoding="ISO88591"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>

负载和输出的XML 
我们要初始化XML分析器,载入XML和输出: 

例如 $xmlDoc = new DOMDocument();
$xmlDoc>load("note.xml");

print $xmlDoc>saveXML();
?> 输出为.Tove Jani Reminder Don't forget me this weekend!如果您选择“查看源文件”在浏览器窗口中,您会看到下面的HTML : <?xml version="1.0" encoding="ISO88591"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>

 

上面的例子中创建的DOMDocument对象并加载XML从“ note.xml ”到它。 

然后saveXML ( )函数来把内部的XML文件到一个字符串,这样我们就可以打印出来。 




通过XML的循环
我们要初始化XML分析器,负载的XML ,并通过回路的所有要素<note>内容: 

例如 <?php
$xmlDoc = new DOMDocument();
$xmlDoc>load("note.xml");

$x = $xmlDoc>documentElement;
foreach ($x>childNodes AS $item)
  {
  print $item>nodeName . " = " . $item>nodeValue . "<br />";
  }
?>

 

结果为.

 

#text = 
to = Tove
#text = 
from = Jani
#text = 
heading = Reminder
#text = 
body = Don't forget me this weekend!
#text =

 

在上面的例子中看到,有空白文本节点之间的每个元素。 

当XML的产生,往往含有白色空间之间的节点。对的XML DOM解析器把这些作为普通的内容,如果你不知道,他们有时会造成问题。转载请注明来自:  www.111cn.net/phper/php.html  

以上代码的输出:

-- Note --
To: George
From: John
Heading: Reminder
Message: Don't forget the meeting!

工作原理解释:
通过 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文档成为可能。

W3C 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”

DOM XML 解析器函数是 PHP 核心的组成部分。无需安装就可以使用这些函数。

XML 文件
将在我们的例子中使用下面的 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>

加载和输出 XML
我们需要初始化 XML 解析器,加载 XML,并把它输出:
例子

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图