首页 > php教程 > php手册 > 正文

php xmlreader simplexml DOMDocument等读取xml的例子

WBOY
发布: 2016-05-23 13:07:30
原创
1519 人浏览过

在php中处理xml文档的类或插件是非常的多了,今天我来为各位介绍xmlreader simplexmlDOMDocument 等读取xml的例子,希望下文能帮助到大家.

要处理 XML 文件,有两种传统的处理思路:SAX 和 DOM,SAX 基于事件触发机制,对 XML 文件进行一次扫描,完成要进行的处理,DOM 则将整个 XML 文件构造为一棵 DOM树,通过对 DOM 树的遍历完成处理,这两种方法各有优缺点,SAX 的处理思路相对抽象,DOM 的处理过程相对烦琐,都不很适合新手的入门。PHP5 推出了一套新的 XML 处理函数,即 SimpleXML,名如其实,SimpleXML 本身小巧精干,只提供了少量的几个方法函数,但用它处理起 XML 文件功能却非常强大,操作也非常的简单.

一,什么是xml,xml有什么用途

XML(Extensible Markup Language)即可扩展标记语言,它与HTML一样,都是SGML(Standard Generalized Markup Language,标准通用标记语言)。Xml是Internet环境中跨平台的,依赖于内容的技术,是当前处理结构化文档信息的有力工具。扩展标记语言XML是一种简单的数据存储语言,使用一系列简单的标记描述数据,而这些标记可以用方便的方式建立,虽然XML占用的空间比二进制数据要占用更多的空间,但XML极其简单易于掌握和使用。

XML的用途很多,可以用来存储数据,可以用来做数据交换,为很多种应用软件提示数据等等。

二,php读取xml的方法

xml源文件代码如下:

<?xml version="1.0" encoding="UTF-8"   
<humans>   
<zhangying>   
<name>张映</name>   
<sex>男</sex>   
<old>28</old>   
</zhangying>   
<tank>   
<name>tank</name>   
<sex>男</sex>   
<old>28</old>   
</tank>   
</humans>
登录后复制

1)DOMDocument读取xml,代码如下:

<?php   
$doc = new DOMDocument();   
$doc->load(&#39;person.xml&#39;);  //读取xml文件   
$humans = $doc->getElementsByTagName( "humans" ); //取得humans标签的对象数组   
foreach( $humans as $human )   
{   
  $names = $human->getElementsByTagName( "name" );//取得name的标签的对象数组   
  $name = $names->item(0)->nodeValue; //取得node中的值,如<name> </name>   
  $sexs = $human->getElementsByTagName( "sex" );   
  $sex = $sexs->item(0)->nodeValue;   
  $olds = $human->getElementsByTagName( "old" );   
  $old = $olds->item(0)->nodeValue;   
  echo "$name - $sex - $old\n";   
}
登录后复制

2)simplexml读取xml,代码如下:

$xml_array=simplexml_load_file(&#39;person.xml&#39;);//将XML中的数据,读取到数组对象中   
foreach($xml_array as $tmp){   
  echo $tmp->name."-".$tmp->sex."-".$tmp->old."<br>";      
}
登录后复制

3)用php正则表达式来记取数据,代码如下:

$xml = "";   
$f = fopen(&#39;person.xml&#39;, &#39;r&#39;);   
while( $data = fread( $f, 4096 ) ) {   
 $xml .= $data;   
}   
fclose( $f );   
// 上面读取数据   
preg_match_all( "/\<humans\>(.*?)\<\/humans\>/s", $xml, $humans );       //匹配最外层标签里面的内容   
foreach( $humans[1] as $k=>$human )   
{   
   preg_match_all( "/\<name\>(.*?)\<\/name\>/", $human, $name );             //匹配出名字   
   preg_match_all( "/\<sex\>(.*?)\<\/sex\>/", $human, $sex );                        //匹配出性别   
   preg_match_all( "/\<old\>(.*?)\<\/old\>/", $human, $old );                        //匹配出年龄   
  }   
foreach($name[1] as $key=>$val){   
  echo $val." - ".$sex[$key][1]." - ".$old[$key][1]."<br>" ;   
}
登录后复制

4)xmlreader来读取xml数据,代码如下:

$reader = new XMLReader();   
$reader->open(&#39;person.xml&#39;);      //读取xml数据   
$i=1;   
while ($reader->read()) {           //是否读取   
 if ($reader->nodeType == XMLReader::TEXT) { //判断node类型   
  if($i%3){   
   echo $reader->value;           //取得node的值   
  }else{   
   echo $reader->value."<br>" ;   
  }   
  $i++;   
 }   
}
登录后复制

使用 DOMDocument 操控 XML

1.DOMDocument 解析 XML,代码如下:

// 创建一个 DOMDocument() 
$_doc = new DOMDocument(); 
// 载入 xml 
$_doc ->load( &#39;test.xml&#39; ); 
// 取 version 标签 
$_version = $_doc ->getElementsByTagName( &#39;version&#39; ); 
echo $_version ->item( 2 )->nodeValue; 
// 遍历 version 标签 
foreach ( $_version as $v ) { 
echo $v ->nodeValue; 
}
登录后复制

2. DOMDocument 生成XML

// 声明 xml 
$_doc = new DOMDocument( &#39;1.0&#39; , &#39;utf-8&#39; ); 
// 排版格式 
$_doc ->formatOutput = true ; 
// 创建一个主标签 
$_root = $_doc ->createElement( &#39;root&#39; ); 
// 创建一个一级标签 version 
$_version = $_doc ->createElement( &#39;version&#39; ); 
// 给 version 标签里赋值 
$_versionTextNode = $_doc ->createTextNode( &#39;1.0&#39; ); 
// 将值放入 version 标签里 
$_version ->appendChild( $_versionTextNode ); 
// 将一级标签 version 放入 root 里 
$_root ->appendChild( $_version ); 
// 将主标签写入 xml 
$_doc ->appendChild( $_root ); 
// 生成 xml 
$_doc ->save( &#39;aaa.xml&#39; );
登录后复制

很多情况下,手工生成标记要求从上到下生成文档,必须保证标签都是完整的,开始和结束标签,尽管借助于一些 PHP 函数或类可以有所改善,不过 PHP 还提供了一组更有帮助的内置对象和函数,文档对象模型,Document Object Model,DOM,提供了一个树状结构,能很容易创建和处理标签.

三,小结

读取xml的方法很多,简单举几个,上面四种方法都是可以把标签中的数据读出来,张映.但是他们的测重点不同,前三种方法的读取xml的function的设计重点,是为了读取标签中的值,相当于jquery中的text()方法,而xmlreader呢他就不太一样,他的重点不在读取标签中的值,而读取标签的属性,把要传送的数据,都放在属性中,不过我上面写的那个方法还是取标签中的值,因为xml文件已经给定了,我就不想在搞xml文件出来了,举个例子解释一下.

xmlreader的设计重点是为了读data里面的name sex old的值,而读取的内容就比较麻烦了,他相当于jquery中attr('');这个东西.


本文地址:

转载随意,但请附上文章地址:-)

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门推荐
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板