博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php xmlreader simplexml等读取xml
阅读量:4921 次
发布时间:2019-06-11

本文共 4356 字,大约阅读时间需要 14 分钟。

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

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

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

二,php读取xml的方法

xml源文件

1 
2
3
4
张映
5
6
28
7
8
9
tank
10
11
28
12
13

1)DOMDocument读取xml

1   
load('person.xml'); //读取xml文件 4 5 $humans = $doc->getElementsByTagName_r( "humans" ); //取得humans标签的对象数组 6 7 foreach( $humans as $human ) 8 { 9 $names = $human->getElementsByTagName_r( "name" ); //取得name的标签的对象数组 10 $name = $names->item(0)->nodeValue; //取得node中的值,如
11 12 $sexs = $human->getElementsByTagName_r( "sex" ); 13 $sex = $sexs->item(0)->nodeValue; 14 15 $olds = $human->getElementsByTagName_r( "old" ); 16 $old = $olds->item(0)->nodeValue; 17 18 echo "$name - $sex - $old\n"; 19 20 } 21 ?>

2)simplexml读取xml

1 
name."-".$tmp->sex."-".$tmp->old."
"; 6 } 7 8 ?>

3)用php正则表达式来记取数据

1 
(.*?)\<\/humans\>/s", $xml, $humans ); //匹配最外层标签里面的内容 10 11 foreach( $humans[1] as $k=>$human ) 12 { 13 preg_match_all( "/\
(.*?)\<\/name\>/", $human, $name ); //匹配出名字 14 preg_match_all( "/\
(.*?)\<\/sex\>/", $human, $sex ); //匹配出性别 15 preg_match_all( "/\
(.*?)\<\/old\>/", $human, $old ); //匹配出年龄 16 } 17 18 foreach($name[1] as $key=>$val){ 19 echo $val." - ".$sex[$key][1]." - ".$old[$key][1]."
" ; 20 } 21 ?>

4)xmlreader来读取xml数据

1 
open('person.xml'); //读取xml数据 4 $i=1; 5 while ($reader->read()) { //是否读取 6 if ($reader->nodeType == XMLReader::TEXT) { //判断node类型 7 if($i%3){ 8 echo $reader->value; //取得node的值 9 }else{ 10 echo $reader->value."
" ; 11 } 12 $i++; 13 } 14 } 15 ?>

三,小结

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

<data name='张映'  sex='男' old='28'></data>

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

上面纯属个人看法,请大家指正

附工作中一个例子:

1 
";11 echo "返回";12 exit;13 }14 15 $save_path = "file/";16 17 $file_name = date(ymdhis).".xml";18 19 if(copy($file,$save_path.$file_name)){20 $xml_array=simplexml_load_file($save_path.$file_name);21 }22 23 foreach($xml_array as $tmp){ 24 foreach($tmp->img as $val){25 $num = strstr($tmp->img->desc[0],'1');26 phpQuery::newDocumentFile("http://www.umishop.com.cn/gallery--n,".rtrim($num)."-grid.html"); 27 $li = pq(".items-gallery")->find("div")->html();28 $link = pq($li)->attr("href");29 if(empty($val->attributes()->buypath) && !empty($link)){30 $val->addAttribute("buypath","{
$link}");31 }else if(!empty($val->attributes()->buypath) && !empty($link)){32 $val->attributes()->buypath = $link;33 }34 } 35 }36 37 file_put_contents($file_name,$xml_array->asXML());38 39 header('Location: http://www.umishop.com/xml/'.$file_name);40 }41 ?>42 43 44 45 xml文件46 47 48
49 上传XML文件
50
51
52 53

 

posted on
2012-12-20 18:04 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/luojianqun/archive/2012/12/20/2826834.html

你可能感兴趣的文章
Java学习从入门到精通
查看>>
查找目录下的所有文件中是否含有某个字符串 linux
查看>>
2018年各大互联网前端面试题四(美团)
查看>>
一起学Python:字符串介绍
查看>>
学习笔记:树状数组
查看>>
洛谷P1772 [ZJOI2006]物流运输 题解
查看>>
CF519E A and B and Lecture Rooms
查看>>
python-redis之数据类型二
查看>>
Java类加载机制
查看>>
循环单链表实现
查看>>
Android设计模式实战---责任链模式
查看>>
剑指Offer_31_整数中1出现的次数(从1到n整数中1出现的次数)
查看>>
10月29日 迅雷会员vip账号分享 91freevip 晚间21:00更新
查看>>
【一题多解】Python 字符串逆序
查看>>
open ball、closed ball 与 open set、closed set(interior point,limit point)、dense set
查看>>
字典(dictionary)与映射(map)
查看>>
Python 编程规范 —— TODO 注释(结合 PyCharm)
查看>>
十万个为什么 —— 名词解释(体育)
查看>>
table的设置(w3c)
查看>>
冲刺一
查看>>