php读取XML的常见方法实例总结

前端之家收集整理的这篇文章主要介绍了php读取XML的常见方法实例总结前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文实例讲述了PHP读取XML的常见方法分享给大家供大家参考,具体如下:

xml源文件

张映 28 tank 28

@H_404_23@

1)

DOMDocument

读取xml

PHP;"> load('person.xml'); //读取xml文件 $humans = $doc->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"; } ?>

@H_404_23@

2)

simplexml

读取xml

PHP;"> name."-".$tmp->sex."-".$tmp->old."
"; } ?>

@H_404_23@

3)用PHP

正则表达式

来读取数据

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

@H_404_23@

4)

xmlreader

来读取xml数据

PHP;"> 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++; } } ?>

@H_404_23@

PS:这里再为大家提供几款关于xml操作的在线工具供大家参考使用:

在线XML/JSON互相转换工具:

在线格式化XML/在线压缩XML:

XML

在线压缩/格式化工具:

XML

代码在线格式化美化工具:

更多关于PHP相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《

希望本文所述对大家PHP程序设计有所帮助。

原文链接:https://www.f2er.com/php/17588.html

猜你在找的PHP相关文章