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的更多相关文章

  1. 读取xml数据装配到字典中之应用场景

    前段时间看到支付宝设置里面有个多语言这个功能,蛮有意思的,就想双休没事的话做个相关的demo玩玩,可是礼拜六被妹子拽出去玩了一天,来大上海有大半年了,基本没有出去玩过,妹子说我是超级宅男,也不带她出去 ...

  2. 自己动手之使用反射和泛型,动态读取XML创建类实例并赋值

    前言: 最近小匹夫参与的游戏项目到了需要读取数据的阶段了,那么觉得自己业余时间也该实践下数据相关的内容.那么从哪入手呢?因为用的是Unity3d的游戏引擎,思来想去就选择了C#读取XML文件这个小功能 ...

  3. MFC如何读取XML

    <?xml version="1.0" encoding="utf-8"?> <Cases> <case> <No&g ...

  4. 使用dom4j读取xml连接数据库与之单例模式

    使用dom4j读取xml ,加入jar包 dom4j-1.6.1.jar jaxen-1.1-beta-6.jar public class XmlConfigReader { //懒汉式,延迟加载 ...

  5. java DOM4J 读取XML

    最近学习Java,在处理XML文档的时候,查阅相关资料,发现了DOM4J这个jre库,相对C#的XML处理来说,功能还算是跟得上 下面展示一篇我自己写的一个XML读取测试 import java.ut ...

  6. C#中常用的读取xml的几种方法(转)

    本文完全来源于http://blog.csdn.net/tiemufeng1122/article/details/6723764,仅作个人学习之用. XML文件是一种常用的文件格式,例如WinFor ...

  7. wcf序列化大对象时报错:读取 XML 数据时,超出最大

    错误为: 访问服务异常:格式化程序尝试对消息反序列化时引发异常: 尝试对参数 http://tempuri.org/ 进行反序列化时出 错: request.InnerException 消息是“反序 ...

  8. C#中常用的几种读取XML文件的方法

    1.C#中常用的几种读取XML文件的方法:http://blog.csdn.net/tiemufeng1122/article/details/6723764/

  9. 利用反射与dom4j读取javabean生成对应XML和读取XML得到对应的javabean对象集合

    转自:http://blog.csdn.net/zhao19861029/article/details/8473245 首先实现生成对应的JAVAbean的XML文件方法 /** * DMO4J写入 ...

  10. 读取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- ...

随机推荐

  1. java 27 - 9 反射之 动态代理的概述和实现

    代理:本来应该自己做的事情,却请了别人来做,被请的人就是代理对象. 举例:春季回家买票让人代买 动态代理: 在程序运行过程中产生的这个对象 而程序运行过程中产生对象其实就是我们刚才反射讲解的内容,所以 ...

  2. 使用eclipse进行Android编程发生崩溃的一个问题及解决办法

    刚才在使用eclipse的时候发生了vm占用过高而无法使用的问题,最初我以为只要重启eclipse就可以解决,重启之后仍然没有效果.重启PC之后打开eclipse仍然无法打开.eclipse是有自己的 ...

  3. CSS3线性渐变和径向渐变

    background:linear-gradient(to top left, blue,orange);//从右下角往左上角渐变 background:radial-gradient(to top ...

  4. sudo命令使用的几个场景

    在linux系统下,普通用户无法直接执行root用户权限下的命令,如果想让普通用户执行只有root用户才能执行的操作命令.下面罗列下经常使用sudo命令的几个场景: 1.用户无权限执行root命令普通 ...

  5. Github 简明教程

    http://www.runoob.com/w3cnote/git-guide.html http://rogerdudler.github.io/git-guide/index.zh.html

  6. BZOJ 1036: [ZJOI2008]树的统计Count

    1036: [ZJOI2008]树的统计Count Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 14354  Solved: 5802 [Subm ...

  7. C#中使用Log4net日志输出到本地文件、Textbox或Listview

    网上很多配置log4net的方法,但是排行靠前的 根本就没有说明清除,导致浪费了两个小时来搞清楚如何配置,真是无语,特写此文,给那些刚接触log4net的朋友 1.参考链接:http://blog.s ...

  8. flex布局模式简单概述

    CSS3中新增一种弹性布局模型:flexbox.网上关于flex的介绍很多,这里介绍下常用的几个属性.弹性布局的特点是非常灵活.可根据剩余的宽高,灵活布局. 先用图片说明flex具有哪些属性.(网上盗 ...

  9. swift---不同字体大小不同颜色label富文本设置

    agreeDeal = UILabel() //富文本,不同字体颜色大小和颜色 let labelString = "登录注册,表示您同意<服务条款及隐私政策>"as ...

  10. Webwork 学习之路【05】请求跳转前 xwork.xml 的读取

    个人理解 WebWork 与 Struts2 都是将xml配置文件作为 Controler 跳转的基本依据,WebWork 跳转 Action 前 xml 文件的读取依赖 xwork-1.0.jar, ...