php下使用SimpleXML 处理XML 文件


Posted in PHP onFebruary 27, 2010

1 SimpleXML 简介
要处理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 的代码出来。

PHP 相关文章推荐
PHP include_path设置技巧分享
Jul 03 PHP
$_GET['goods_id']+0 的使用详解
Jun 06 PHP
解析阿里云ubuntu12.04环境下配置Apache+PHP+PHPmyadmin+MYsql
Jun 26 PHP
MongoDB在PHP中的常用操作小结
Feb 20 PHP
php利用scws实现mysql全文搜索功能的方法
Dec 25 PHP
php实现图片等比例缩放代码
Jul 23 PHP
PHP实现微信发红包程序
Aug 24 PHP
PHP实现登陆表单提交CSRF及验证码
Jan 24 PHP
php实现多维数组排序的方法示例
Mar 23 PHP
YII2框架中excel表格导出的方法详解
Jul 21 PHP
PHP通过bypass disable functions执行系统命令的方法汇总
May 02 PHP
PHP连接MSSQL数据库案例,PHPWAMP多个PHP版本连接SQL Server数据库
Apr 16 PHP
PHP 导出数据到淘宝助手CSV的方法分享
Feb 27 #PHP
基于pear auth实现登录验证
Feb 26 #PHP
php str_pad() 将字符串填充成指定长度的字符串
Feb 23 #PHP
php 用checkbox一次性删除多条记录的方法
Feb 23 #PHP
PHP实现域名whois查询的代码(数据源万网、新网)
Feb 22 #PHP
PHP 伪静态隐藏传递参数名的四种方法
Feb 22 #PHP
收藏的PHP常用函数 推荐收藏保存
Feb 21 #PHP
You might like
php代码优化及php相关问题总结
2006/10/09 PHP
php防止网站被刷新的方法汇总
2014/12/01 PHP
PHP简单预防sql注入的方法
2016/09/27 PHP
动态创建的表格单元格中的事件实现代码
2008/12/30 Javascript
window.onbeforeunload方法在IE下无法正常工作的解决办法
2010/01/23 Javascript
浅谈tudou土豆网首页图片延迟加载的效果
2010/06/23 Javascript
jQuery+.net实现浏览更多内容(改编php版本)
2013/03/28 Javascript
在JavaScript中操作数组之map()方法的使用
2015/06/09 Javascript
AngularJs解决跨域问题案例详解(简单方法)
2016/05/19 Javascript
深入理解JQuery循环绑定事件
2016/06/02 Javascript
浅谈js多维数组和hash数组定义和使用
2016/07/27 Javascript
js表单登陆验证示例
2016/10/19 Javascript
Angular2开发——组件规划篇
2017/03/28 Javascript
JS实现AES加密并与PHP互通的方法分析
2017/04/19 Javascript
让你5分钟掌握9个JavaScript小技巧
2018/06/09 Javascript
JavaScript面向对象继承原理与实现方法分析
2018/08/09 Javascript
iview在vue-cli3如何按需加载的方法
2018/10/31 Javascript
详解async/await 异步应用的常用场景
2019/05/13 Javascript
JS实现纵向轮播图(初级版)
2020/01/18 Javascript
python根据出生日期返回年龄的方法
2015/03/26 Python
Python排序搜索基本算法之堆排序实例详解
2017/12/08 Python
python解决pandas处理缺失值为空字符串的问题
2018/04/08 Python
如何基于pythonnet调用halcon脚本
2020/01/20 Python
python dict乱码如何解决
2020/06/07 Python
Python3爬虫中关于中文分词的详解
2020/07/29 Python
Python pathlib模块使用方法及实例解析
2020/10/05 Python
HTML5 weui使用笔记
2019/11/21 HTML / CSS
新加坡领先的在线生活方式和杂货购物网站:EAMART
2019/04/02 全球购物
说出数据连接池的工作机制是什么?
2013/04/19 面试题
什么是View State?
2013/01/27 面试题
护士演讲稿范文
2014/01/05 职场文书
2016年清明节期间群众祭祀活动工作总结
2016/04/01 职场文书
2019旅游导游工作总结
2019/06/27 职场文书
企业管理不到位检讨书
2019/06/27 职场文书
浅谈Python从全局与局部变量到装饰器的相关知识
2021/06/21 Python
Mysql关于数据库是否应该使用外键约束详解说明
2021/10/24 MySQL