您好,欢迎访问一九零五行业门户网

php xmlreader simplexml DOMDocument等读取xml的例子

在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源文件代码如下:
getelementsbytagname( humans ); //取得humans标签的对象数组 foreach( $humans as $human ) { $names = $human->getelementsbytagname( name );//取得name的标签的对象数组 $name = $names->item(0)->nodevalue; //取得node中的值,如 $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('person.xml');//将xml中的数据,读取到数组对象中 foreach($xml_array as $tmp){ echo $tmp->name.-.$tmp->sex.-.$tmp->old.
; }
3)用php正则表达式来记取数据,代码如下:
$xml = ; $f = fopen('person.xml', 'r'); while( $data = fread( $f, 4096 ) ) { $xml .= $data; } fclose( $f ); // 上面读取数据 preg_match_all( /\(.*?)\/s, $xml, $humans ); //匹配最外层标签里面的内容 foreach( $humans[1] as $k=>$human ) { preg_match_all( /\(.*?)\/, $human, $name ); //匹配出名字 preg_match_all( /\(.*?)\/, $human, $sex ); //匹配出性别 preg_match_all( /\(.*?)\/, $human, $old ); //匹配出年龄 } foreach($name[1] as $key=>$val){ echo $val. - .$sex[$key][1]. - .$old[$key][1].
; }
4)xmlreader来读取xml数据,代码如下:
$reader = new xmlreader(); $reader->open('person.xml'); //读取xml数据 $i=1; while ($reader->read()) { //是否读取 if ($reader->nodetype == xmlreader::text) { //判断node类型 if($i%3){ echo $reader->value; //取得node的值 }else{ echo $reader->value.
; } $i++; } }
使用 domdocument 操控 xml
1.domdocument 解析 xml,代码如下:
// 创建一个 domdocument() $_doc = new domdocument(); // 载入 xml $_doc ->load( 'test.xml' ); // 取 version 标签 $_version = $_doc ->getelementsbytagname( 'version' ); echo $_version ->item( 2 )->nodevalue; // 遍历 version 标签 foreach ( $_version as $v ) { echo $v ->nodevalue; }
2. domdocument 生成xml
// 声明 xml $_doc = new domdocument( '1.0' , 'utf-8' ); // 排版格式 $_doc ->formatoutput = true ; // 创建一个主标签 $_root = $_doc ->createelement( 'root' ); // 创建一个一级标签 version $_version = $_doc ->createelement( 'version' ); // 给 version 标签里赋值 $_versiontextnode = $_doc ->createtextnode( '1.0' ); // 将值放入 version 标签里 $_version ->appendchild( $_versiontextnode ); // 将一级标签 version 放入 root 里 $_root ->appendchild( $_version ); // 将主标签写入 xml $_doc ->appendchild( $_root ); // 生成 xml $_doc ->save( 'aaa.xml' );
很多情况下,手工生成标记要求从上到下生成文档,必须保证标签都是完整的,开始和结束标签,尽管借助于一些 php 函数或类可以有所改善,不过 php 还提供了一组更有帮助的内置对象和函数,文档对象模型,document object model,dom,提供了一个树状结构,能很容易创建和处理标签.
三,小结
读取xml的方法很多,简单举几个,上面四种方法都是可以把标签中的数据读出来,张映.但是他们的测重点不同,前三种方法的读取xml的function的设计重点,是为了读取标签中的值,相当于jquery中的text()方法,而xmlreader呢他就不太一样,他的重点不在读取标签中的值,而读取标签的属性,把要传送的数据,都放在属性中,不过我上面写的那个方法还是取标签中的值,因为xml文件已经给定了,我就不想在搞xml文件出来了,举个例子解释一下.
xmlreader的设计重点是为了读data里面的name sex old的值,而读取的内容就比较麻烦了,他相当于jquery中attr('');这个东西.
本文地址:
转载随意,但请附上文章地址:-)
其它类似信息

推荐信息