PHP读取XML
books.xml文件:
代码 <books>
<book>
<author>Jack Herrington</author>
<title>PHP Hacks</title>
<publisher>O'Reilly</publisher>
</book>
<book>
<author>Jack Herrington</author>
<title>Podcasting Hacks</title>
<publisher>O'Reilly</publisher>
</book>
</books>
1.DOMDocument方法
代码 1 <?php
2 $doc = new DOMDocument();
3 $doc->load( 'books.xml' );
4 $books = $doc->getElementsByTagName( "book" );
5 foreach( $books as $book )
6 {
7 $authors = $book->getElementsByTagName( "author" );
8 $author = $authors->item(0)->nodeValue;
9
10 $publishers = $book->getElementsByTagName( "publisher" );
11 $publisher = $publishers->item(0)->nodeValue;
12
13 $titles = $book->getElementsByTagName( "title" );
14 $title = $titles->item(0)->nodeValue;
15
16 echo "$title - $author - $publisher\n";
17 echo "<br>";
18 }
19 ?>
2.用 SAX 解析器读取 XML
代码 1 <?php
2 $g_books = array();
3 $g_elem = null;
4
5 function startElement( $parser, $name, $attrs )
6 {
7 global $g_books, $g_elem;
8 if ( $name == 'BOOK' ) $g_books []= array();
9 $g_elem = $name;
10 }
11
12 function endElement( $parser, $name )
13 {
14 global $g_elem;
15 $g_elem = null;
16 }
17
18 function textData( $parser, $text )
19 {
20 global $g_books, $g_elem;
21 if ( $g_elem == 'AUTHOR' ||
22 $g_elem == 'PUBLISHER' ||
23 $g_elem == 'TITLE' )
24 {
25 $g_books[ count( $g_books ) - 1 ][ $g_elem ] = $text;
26 }
27 }
28
29 $parser = xml_parser_create();
30
31 xml_set_element_handler( $parser, "startElement", "endElement" );
32 xml_set_character_data_handler( $parser, "textData" );
33
34 $f = fopen( 'books.xml', 'r' );
35
36 while( $data = fread( $f, 4096 ) )
37 {
38 xml_parse( $parser, $data );
39 }
40
41 xml_parser_free( $parser );
42
43 foreach( $g_books as $book )
44 {
45 echo $book['TITLE']." - ".$book['AUTHOR']." - ";
46 echo $book['PUBLISHER']."\n";
47 }
48 ?>
3.用正则表达式解析 XML
代码 1 <?php
2 $xml = "";
3 $f = fopen( 'books.xml', 'r' );
4 while( $data = fread( $f, 4096 ) ) {
5 $xml .= $data;
6 }
7 fclose( $f );
8
9 preg_match_all( "/\<book\>(.*?)\<\/book\>/s", $xml, $bookblocks );
10
11 foreach( $bookblocks[1] as $block )
12 {
13 preg_match_all( "/\<author\>(.*?)\<\/author\>/", $block, $author );
14 preg_match_all( "/\<title\>(.*?)\<\/title\>/", $block, $title );
15 preg_match_all( "/\<publisher\>(.*?)\<\/publisher\>/", $block, $publisher );
16 echo( $title[1][0]." - ".$author[1][0]." - ".$publisher[1][0]."\n" );
17 }
18 ?>
4.解析XML到数 组
代码 1 <?php
2 $data = "<root><line /><content language=\"gb2312\">简单的XML数据</content></root>";
3 $parser = xml_parser_create(); //创建解析器
4 xml_parse_into_struct($parser, $data, $values, $index); //解析到数组
5 xml_parser_free($parser); //释放资源
6
7 //显示数组结构
8 echo "\n索引数组\n";
9 print_r($index);
10 echo "\n数据数组\n";
11 print_r($values);
12 ?>
5.检查XML是否有效
代码 1 <?php
2 //创建XML解析器
3 $xml_parser = xml_parser_create();
4
5 //使用大小写折叠来保证能在元素数组中找到这些元素名称
6 xml_parser_set_option($xml_parser, XML_OPTION_CASE_FOLDING, true);
7
8 //读取XML文件
9 $xmlfile = "bb.xml";
10 if (!($fp = fopen($xmlfile, "r")))
11 {
12 die("无法读取XML文件$xmlfile");
13 }
14
15 //解析XML文件
16 $has_error = false; //标志位
17 while ($data = fread($fp, 4096))
18 {
19 //循环地读入XML文档,只到文档的EOF,同时停止解析
20 if (!xml_parse($xml_parser, $data, feof($fp)))
21 {
22 $has_error = true;
23 break;
24 }
25 }
26
27 if($has_error)
28 {
29 echo "该XML文档是错误的!<br />";
30
31 //输出错误行,列及其错误信息
32 $error_line = xml_get_current_line_number($xml_parser);
33 $error_row = xml_get_current_column_number($xml_parser);
34 $error_string = xml_error_string(xml_get_error_code($xml_parser));
35
36 $message = sprintf("[第%d行,%d列]:%s",
37 $error_line,
38 $error_row,
39 $error_string);
40 echo $message;
41 }
42 else
43 {
44 echo "该XML文档是结构良好的。";
45 }
46
47 //关闭XML解析器指针,释放资源
48 xml_parser_free($xml_parser);
49 ?>
6.可用于精确的读取XML
test.xml
代码 1 <?xml version="1.0" encoding="UTF-8" ?>
2 <SBMP_MO_MESSAGE>
3 <CONNECT_ID>100</CONNECT_ID>
4 <MO_MESSAGE_ID>123456</MO_MESSAGE_ID>
5 <RECEIVE_DATE>20040605</RECEIVE_DATE>
6 <RECEIVE_TIME>153020</RECEIVE_TIME>
7 <GATEWAY_ID>1</GATEWAY_ID>
8 <VALID>1</VALID>
9 <CITY_CODE>010</CITY_CODE>
10 <CITY_NAME>北京</CITY_NAME>
11 <STATE_CODE>010</STATE_CODE>
12 <STATE_NAME>北京</STATE_NAME>
13 <TP_PID>0</TP_PID>
14 <TP_UDHI>0</TP_UDHI>
15 <MSISDN>15933626501</MSISDN>
16 <MESSAGE_TYPE>8</MESSAGE_TYPE>
17 <MESSAGE>5618常年供应苗木,品种有玉兰、黄叶杨等。联系人:张三,电话:1234567890。</MESSAGE>
18 <LONG_CODE>100</LONG_CODE>
19 <SERVICE_CODE>9588</SERVICE_CODE>
20 </SBMP_MO_MESSAGE>
21 test.php:
22 <?php
23 $myData = array();
24 $file = file_get_contents("test.xml");
25 if(strpos($file, '<?xml') > -1) {
26 try {
27 //加载解析xml
28 $xml = simplexml_load_string($file);
29 if($xml) {
30 //echo $this->result;
31 //获取节点值
32 $CONNECT_ID = $xml->CONNECT_ID;
33 $MO_MESSAGE_ID = $xml->MO_MESSAGE_ID;
34 $RECEIVE_DATE = $xml->RECEIVE_DATE;
35 $RECEIVE_TIME = $xml->RECEIVE_TIME;
36 $GATEWAY_ID = $xml->GATEWAY_ID;
37 $VALID = $xml->VALID;
38 $CITY_CODE = $xml->CITY_CODE;
39 $CITY_NAME = $xml->CITY_NAME;
40 $STATE_CODE = $xml->CITY_CODE;
41 $STATE_NAME = $xml->STATE_NAME;
42 $TP_PID = $xml->TP_PID;
43 $TP_UDHI = $xml->TP_UDHI;
44 $MSISDN = $xml->MSISDN;
45 $MESSAGE_TYPE = $xml->MESSAGE_TYPE;
46 $MESSAGE = $xml->MESSAGE;//短信
47 $LONG_CODE = $xml->LONG_CODE;
48 $SERVICE_CODE = $xml->SERVICE_CODE;
49 preg_match("/(561)\d{1,2}/", $MESSAGE, $code);
50 switch($code[0]) {
51 case 5618 :
52 $myData[message] = $MESSAGE;
53 break;
54 default :
55 $myData[] = '没有短消息。';
56 break;
57 }
58
59 } else {
60 echo "加载xml文件错误。";
61 }
62
63 } catch(exception $e){
64 print_r($e);
65 }
66
67 } else {
68 echo "没有该XML文件。";
69 }
70
71 echo "<pre>";
72 print_r($myData);
73 echo "<hr>";
74 echo $myData[message];
75 ?>
PHP读取XML的更多相关文章
- 读取xml数据装配到字典中之应用场景
前段时间看到支付宝设置里面有个多语言这个功能,蛮有意思的,就想双休没事的话做个相关的demo玩玩,可是礼拜六被妹子拽出去玩了一天,来大上海有大半年了,基本没有出去玩过,妹子说我是超级宅男,也不带她出去 ...
- 自己动手之使用反射和泛型,动态读取XML创建类实例并赋值
前言: 最近小匹夫参与的游戏项目到了需要读取数据的阶段了,那么觉得自己业余时间也该实践下数据相关的内容.那么从哪入手呢?因为用的是Unity3d的游戏引擎,思来想去就选择了C#读取XML文件这个小功能 ...
- MFC如何读取XML
<?xml version="1.0" encoding="utf-8"?> <Cases> <case> <No&g ...
- 使用dom4j读取xml连接数据库与之单例模式
使用dom4j读取xml ,加入jar包 dom4j-1.6.1.jar jaxen-1.1-beta-6.jar public class XmlConfigReader { //懒汉式,延迟加载 ...
- java DOM4J 读取XML
最近学习Java,在处理XML文档的时候,查阅相关资料,发现了DOM4J这个jre库,相对C#的XML处理来说,功能还算是跟得上 下面展示一篇我自己写的一个XML读取测试 import java.ut ...
- C#中常用的读取xml的几种方法(转)
本文完全来源于http://blog.csdn.net/tiemufeng1122/article/details/6723764,仅作个人学习之用. XML文件是一种常用的文件格式,例如WinFor ...
- wcf序列化大对象时报错:读取 XML 数据时,超出最大
错误为: 访问服务异常:格式化程序尝试对消息反序列化时引发异常: 尝试对参数 http://tempuri.org/ 进行反序列化时出 错: request.InnerException 消息是“反序 ...
- C#中常用的几种读取XML文件的方法
1.C#中常用的几种读取XML文件的方法:http://blog.csdn.net/tiemufeng1122/article/details/6723764/
- 利用反射与dom4j读取javabean生成对应XML和读取XML得到对应的javabean对象集合
转自:http://blog.csdn.net/zhao19861029/article/details/8473245 首先实现生成对应的JAVAbean的XML文件方法 /** * DMO4J写入 ...
- 读取xml文件报错:Invalid byte 2 of 2-byte UTF-8 sequence。
程序读取xml文件后,系统报“Invalid byte 2 of 2-byte UTF-8 sequence”错误,如何解决呢? 1.程序解析xml的时候,出现Invalid byte 2 of 2- ...
随机推荐
- JIRA学习一:Windows下安装破解JIRA6.3.6
安装环境: WindowsXP MySQL-5.5.28 JDK1.6.0_21 JIRA功能全面,界面友好,安装简单,配置灵活,权限管理以及可扩展性方面都十分出色. 一.MySQL建库和建账号 1. ...
- Windows 7 USB DVD Download Tool
1.下载.安装.运行Windows 7 USB DVD Download Tool: 百度官方下载 http://rj.baidu.com/soft/detail/20458.html 2.点击&qu ...
- HTML 学习笔记 CSS3(过度 transition)
通过 CSS3,我们可以在不使用 Flash 动画或 JavaScript 的情况下,当元素从一种样式变换为另一种样式时为元素添加效果.请把鼠标移动到下面的元素上: 先看一下这个代码 实现旋转放大的效 ...
- Markdown:认识&入门
来源:http://sspai.com/25137 一.认识 Markdown 在刚才的导语里提到,Markdown 是一种用来写作的轻量级「标记语言」,它用简洁的语法代替排版,而不像一般我们用的字处 ...
- 030医疗项目-模块三:药品供应商目录模块——供货商药品目录查询功能----------Dao层:基本的查询语句的编写
我们安装显示的要求: 我们能看到显示的目录里面有:供货企业的名字(这个数据来自于供货商的表[usergys]),流水号,通用名,剂型(这些都来自药品信息表),供货的状态(这个呢在gysypml_con ...
- Windows 8 开发系列汇总
Windows 8 应用开发 Windows 8 应用开发 - 异步调用 Windows 8 应用开发 - 本地数据存储 Windows 8 应用开发 - 挂起与恢复 Windows 8 应用开发 - ...
- Elasticsearch-2.3.x填坑之路
使用版本说明:2.3.2 强制不能使用root用户启动?因为在2.x版本强调了安全性,防止attracker侵入root用户,所以建议使用者创建其他用户启动.当然,可以通过配置来实现root用户启动. ...
- zabbix常用术语
zabbix常用术语
- Caffe学习系列(3):视觉层(Vision Layers)及参数
所有的层都具有的参数,如name, type, bottom, top和transform_param请参看我的前一篇文章:Caffe学习系列(2):数据层及参数 本文只讲解视觉层(Vision La ...
- FastFourierTransform (FFT)
FastFourierTransform.h #pragma once #include <stdio.h> #include <math.h> #ifndef INCLUDE ...