Home > php教程 > php手册 > body text

php xmlreader simplexml DOMDocument等读取xml的例子

WBOY
Release: 2016-05-23 13:07:30
Original
1518 people have browsed it

在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>
Copy after login

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";   
}
Copy after login

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>";      
}
Copy after login

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>" ;   
}
Copy after login

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++;   
 }   
}
Copy after login

使用 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; 
}
Copy after login

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; );
Copy after login

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

三,小结

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

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


本文地址:

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

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Recommendations
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template