**PHP SimpleXML 使用详细例子

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 要处理XML 文件,有两种传统的处理思路:SAX 和DOM。SAX 基于事件触发机制, 对XML 文件进行一次扫描,完成要进行的处理;DOM 则将整个XML 文件构造为一棵DOM 树,通过对DOM 树的遍历完成处理。

要处理XML 文件,有两种传统的处理思路:SAX 和DOM。SAX 基于事件触发机制, 
对XML 文件进行一次扫描,完成要进行的处理;DOM 则将整个XML 文件构造为一棵DOM 
树,通过对DOM 树的遍历完成处理。这两种方法各有优缺点,SAX 的处理思路相对抽象, 
DOM 的处理过程相对烦琐,都不很适合新手的入门。 
PHP5 推出了一套新的XML 处理函数,即SimpleXML。名如其实,SimpleXML 本身小 
巧精干,只提供了少量的几个方法函数,但用它处理起XML 文件功能却非常强大,操作也 
非常的简单。 
首先,它提供有简单的函数可以从XML 文档、字符串、或DOM 对象上直接构造出 
SimpleXMLElement 对象;其次,SimpleXMLElement 提供有简单的方法可以进行属性、子节 
点、和XPath 的操作;然而,SimpleXML 最简单的地方是,它提供有使用标准对象的属性和 
对象迭代器进行节点操作的方法,这一处理思路使得用PHP 对XML 文档的处理得到了极大 
的简化。 
2 SimpleXML 入门示例 
下面我们通过一些小的代码片段,稍微了解一下SimpleXML 的强大和简洁。为举例方便, 
我们使用一个Messages.xml 文件,里面包含这样一段XML 代码: 
Messages.xml 

复制代码代码如下:

<?xml version='1.0' standalone='yes'?> 
<Messages> 
<msg id='1'> 
<title>This is Title</title> 
<content>Here is Content</content> 
<time>2008-03-20 21:50:23</time> 
<reply id='11'>reply 1</reply> 
<reply id='12'>reply 2</reply> 
</msg> 
</Messages> 


这是一篇保存有留言信息的XML 文档,每条信息包括属性id,子节点title、content、time 
以及若干条对于它的回复信息,每条回复包括属性id 及回复的内容。 
用SimpleXML 处理并输出此XML 文档内容的过程以及方法如下。 
(1) 构造SimpleXMLElement 对象 

代码片断 
$xml = simplexml_load_file('Messages.xml'); 
如果这段xml 已经被读入到一个字符串$messages 中,则可以使用如下语句: 
代码片断 
$xml = simplexml_load_string('Messages.xml'); 
(2)输出留言1 的标题 
代码片断 
//可以使用属性的方式访问子节点,通过节点的标签名可直接得到节点的内容 
echo $xml->msg->title; 
(3)输出留言1 的第一条回复信息 
代码片断 
//同级别的多个同名节点自动成为数组,可以通过索引下标访问其内容 
echo $xml->msg->reply[0]; 
(4)输出留言的id 
代码片断 
//节点的属性与值被封装成为关联数组的键与值 
echo $xml->msg['id']; 
(5)输出第二条回复的id 
代码片断 
//成为二维数组,第一维表示节点,第二维表示属性 
echo $xml->msg->reply[1][ 'id']; 
(6)依次输出所有回复的id 
代码片断 
//使用foreach 对同名节点进行遍历 
foreach ($xml->msg->reply as $reply){ 
echo $reply['id']; 

(7)使用XPath 检索所有的回复信息 
代码片断 
//xpath 方法直接检索定位(//表示任意深度) 
foreach ($xml->xpath('//reply') as $reply){ 
echo $reply.'<br>'; 


(8)遍历留言1 所有的子节点 
代码片断 
//children 方法得到所有子节点 
foreach ($xml->msg->children() as $field){ 
echo $field.'<br>'; 

(9)重新设置留言1 的发布时间 
代码片断 
//直接设置属性 
$xml->msg->time = '2008-03-21 00:53:12'; 
(10)设置回复2 的id 属性 
代码片断 
//设置管理数组的值 
$xml->msg->reply[1]['id'] = '222'; 
(11)新增一个描述消息作者的字段 
代码片断 
//直接设置属性 
$xml->msg->author = 'zhangsan'; 
(12)将消息的作者保存为属性 
代码片断 
//设置关联数组的key 
$xml->msg['author'] = 'zhangsan'; 
(13)重新保存对象到文件 
代码片断 
//保存 
$xml->asXML('MessagesNew.xml'); 
应该可以看出SimpleXML 有多简单了吧! 
3 实例:XML 文件与数据库之间进行数据交互 
下面提供一个相对完整的实例,将留言信息从MySQL 数据库中查询出来,保存成为一 
个如上例所示的XML 文件。留言信息和回复信息独立保存在两张表中,使用MySQL 函数包 
可以非常简单地实现如下: 

代码如下: 

复制代码代码如下:

<?php 
//cong work atWed Mar 20 19:59:04 CST 2008 
//将数据从MySQL 数据库中保存到XML 文件中 
//可以使用如下几种方式构造初始的SimpleXMLElement 对象 
//1、从DOM 对象中构造 
//$dom = new DOMDocument(); 
//$dom->loadXML("<rows></rows>"); 
//$xml = simplexml_import_dom($dom); 
//2、从仅包含根标签的xml 文件中构造 
//$xml = simplexml_load_file('messages.xml'); 
//3、直接写根标签字符串构造 
//$xml = simplexml_load_string("<Messages></Messages>"); 
//4、使用SimpleXMLElement 类的构造器构造 
$xml = new SimpleXMLElement('<Messages></Messages>'); 
//连接数据库 
mysql_connect('localhost','root','root'); 
mysql_select_db('test'); 
mysql_query('set names utf8'); 
//查询消息 
$rs = mysql_query("select * from messages"); 
$i = 0; //用做多条消息的数组索引下标 
while($row = mysql_fetch_assoc($rs)){ 
$xml->message[$i] = ''; //… … … … … … … … … … … … ① 
$xml->message[$i]['id'] = $row['id']; 
$xml->message[$i]->title = $row['title']; 
$xml->message[$i]->content = $row['content']; 
$xml->message[$i]->time = $row['time']; 
//根据消息id 查询它相关的回复信息 
$rsReply = mysql_query("select * from replies where mid={$row['id']}"); 
$j = 0; //用于做多条回复的索引下标 
while($rowReply = mysql_fetch_assoc($rsReply)){ 
$xml->message[$i]->reply[$j] = $rowReply['reply']; 
$xml->message[$i]->reply[$j]['id'] = $rowReply['id']; 
$j++; 

$i++; 

$xml->asXML('messages.xml'); 
?> 


上述代码唯一值得一提的地方就是标志①的那行。当我们要向一个SimpleXML 对象中新 
增一个节点或属性时,必须保证它的父节点是存在的,否则会报一个致命错误,提示信息是: 
Objects used as arrays in post/pre increment/decrement must return values by reference。希望大家

不要被这段不知所云的提示所迷惑。相信读者能通过对上述代码的了解,对等地写出一个从XML文件到MySQL 的代码出来。

 

转自http://www.jb51.net/article/22265.htm 

如何联系我:【万里虎】www.bravetiger.cn 【QQ】3396726884 (咨询问题100元起,帮助解决问题500元起) 【博客】http://www.cnblogs.com/kenshinobiy/
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
9月前
|
XML JSON PHP
PHP快速入门08-JSON与XML处理
PHP快速入门与实战JSON与XML都是用于在不同的应用程序之间传输数据的格式化语言。在PHP中,可以使用内置函数处理JSON和XML格式的数据。以上就是关于本篇文章介绍的内容,JSON与XML处理,后续更多内容将收录在专栏PHP快速入门与实战。
|
XML JSON API
PHP中simplexml_load_string解析xml的正确方式
对接我php接口的是安卓客户端,json字符串中在一个元素的时候是对象类型,多个元素的时候是数组类型,安卓客户端解析就失败了。 所以引申出这篇文章,详细测试、记录一下php中解析xml方式和细节
187 0
|
XML JSON PHP
PHP解析json、xml错误
php内置函数json_decode() 可以解析json字符串 但是有的时候看起来正确的json,解析却一直返回null。 你知道吗,json是可能解析失败的,此时PHP不会产生提示。 我们需要手动通过json_last_error()函数获取
184 0
|
XML PHP 数据格式
【PHP】xml转为数组
【PHP】xml转为数组
101 0
|
XML PHP 数据格式