久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP讀取XML格式文件的方法總結(jié)

這篇文章主要介紹了PHP讀取XML格式文件的方法,結(jié)合實(shí)例形式總結(jié)分析了php針對(duì)xml格式文件的讀取、解析、加載、遍歷等操作技巧,需要的朋友可以參考下

本文實(shí)例總結(jié)了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方法

<?php
$doc = new DOMDocument();
$doc->load( 'books.xml' );
$books = $doc->getElementsByTagName( "book" );
foreach( $books as $book )
{
$authors = $book->getElementsByTagName( "author" );
$author = $authors->item(0)->nodeValue;
$publishers = $book->getElementsByTagName( "publisher" );
$publisher = $publishers->item(0)->nodeValue;
$titles = $book->getElementsByTagName( "title" );
$title = $titles->item(0)->nodeValue;
echo "$title - $author - $publisher\n";
echo "<br>";
}
?>

2.用 SAX 解析器讀取 XML:

<?php
$g_books = array();
$g_elem = null;
function startElement( $parser, $name, $attrs ) 
{
global $g_books, $g_elem;
if ( $name == 'BOOK' ) $g_books []= array();
$g_elem = $name;
}
function endElement( $parser, $name ) 
{
global $g_elem;
$g_elem = null;
}
function textData( $parser, $text )
{
global $g_books, $g_elem;
if ( $g_elem == 'AUTHOR' ||
$g_elem == 'PUBLISHER' ||
$g_elem == 'TITLE' )
{
$g_books[ count( $g_books ) - 1 ][ $g_elem ] = $text;
}
}
$parser = xml_parser_create();
xml_set_element_handler( $parser, "startElement", "endElement" );
xml_set_character_data_handler( $parser, "textData" );
$f = fopen( 'books.xml', 'r' );
while( $data = fread( $f, 4096 ) )
{
xml_parse( $parser, $data );
}
xml_parser_free( $parser );
foreach( $g_books as $book )
{
echo $book['TITLE']." - ".$book['AUTHOR']." - ";
echo $book['PUBLISHER']."\n";
}
?>

3.用正則表達(dá)式解析 XML:

<?php
$xml = "";
$f = fopen( 'books.xml', 'r' );
while( $data = fread( $f, 4096 ) ) {
  $xml .= $data; 
}
fclose( $f );
preg_match_all( "/\<book\>(.*?)\<\/book\>/s", $xml, $bookblocks );
foreach( $bookblocks[1] as $block )
{
preg_match_all( "/\<author\>(.*?)\<\/author\>/", $block, $author );
preg_match_all( "/\<title\>(.*?)\<\/title\>/",  $block, $title );
preg_match_all( "/\<publisher\>(.*?)\<\/publisher\>/", $block, $publisher );
echo( $title[1][0]." - ".$author[1][0]." - ".$publisher[1][0]."\n" );
}
?>

4.解析XML到數(shù)組

<?php
  $data = "<root><line /><content language=\"gb2312\">簡(jiǎn)單的XML數(shù)據(jù)</content></root>";
  $parser = xml_parser_create(); //創(chuàng)建解析器
  xml_parse_into_struct($parser, $data, $values, $index); //解析到數(shù)組
  xml_parser_free($parser); //釋放資源
  //顯示數(shù)組結(jié)構(gòu)
  echo "\n索引數(shù)組\n";
  print_r($index);
  echo "\n數(shù)據(jù)數(shù)組\n";
  print_r($values);
?>

5.檢查XML是否有效

<?php
  //創(chuàng)建XML解析器
  $xml_parser = xml_parser_create();
  //使用大小寫(xiě)折疊來(lái)保證能在元素?cái)?shù)組中找到這些元素名稱(chēng)
  xml_parser_set_option($xml_parser, XML_OPTION_CASE_FOLDING, true);
  //讀取XML文件
  $xmlfile = "bb.xml";
  if (!($fp = fopen($xmlfile, "r")))
  {
    die("無(wú)法讀取XML文件$xmlfile");
  }
  //解析XML文件
  $has_error = false;      //標(biāo)志位
  while ($data = fread($fp, 4096))
  {
    //循環(huán)地讀入XML文檔,只到文檔的EOF,同時(shí)停止解析
    if (!xml_parse($xml_parser, $data, feof($fp)))
    {
      $has_error = true;
      break;
    }
  }
  if($has_error)
  { 
    echo "該XML文檔是錯(cuò)誤的!<br />";
    //輸出錯(cuò)誤行,列及其錯(cuò)誤信息
    $error_line  = xml_get_current_line_number($xml_parser);
    $error_row  = xml_get_current_column_number($xml_parser);
    $error_string = xml_error_string(xml_get_error_code($xml_parser));
    $message = sprintf("[第%d行,%d列]:%s", 
            $error_line,
            $error_row,
            $error_string);
    echo $message;
  }
  else
  {
    echo "該XML文檔是結(jié)構(gòu)良好的。";
  }
  //關(guān)閉XML解析器指針,釋放資源
  xml_parser_free($xml_parser);
?>

6.可用于精確的讀取XML

test.xml

<?xml version="1.0" encoding="UTF-8" ?>
  <SBMP_MO_MESSAGE>
    <CONNECT_ID>100</CONNECT_ID>
    <MO_MESSAGE_ID>123456</MO_MESSAGE_ID>
    <RECEIVE_DATE>20040605</RECEIVE_DATE>
    <RECEIVE_TIME>153020</RECEIVE_TIME>
    <GATEWAY_ID>1</GATEWAY_ID>
    <VALID>1</VALID>
    <CITY_CODE>010</CITY_CODE>
    <CITY_NAME>北京</CITY_NAME>
    <STATE_CODE>010</STATE_CODE>
    <STATE_NAME>北京</STATE_NAME>
    <TP_PID>0</TP_PID>
    <TP_UDHI>0</TP_UDHI>
    <MSISDN>15933626501</MSISDN>
    <MESSAGE_TYPE>8</MESSAGE_TYPE>
    <MESSAGE>5618常年供應(yīng)苗木,品種有玉蘭、黃葉楊等。聯(lián)系人:張三,電話(huà):1234567890。</MESSAGE>
    <LONG_CODE>100</LONG_CODE>
    <SERVICE_CODE>9588</SERVICE_CODE>
  </SBMP_MO_MESSAGE>

【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡(jiǎn)單分析了插值查找算法的概念、原理并結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)針對(duì)有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實(shí)現(xiàn)服務(wù)端分頁(yè)的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇PHP實(shí)現(xiàn)APP微信支付的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
這篇文章主要介紹了PHP實(shí)現(xiàn)的多維數(shù)組排序算法,結(jié)合實(shí)例形式對(duì)比分析了php針對(duì)多維數(shù)組及帶有鍵名的多維數(shù)組進(jìn)行排序相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實(shí)現(xiàn)無(wú)刷新文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開(kāi)發(fā)接口使用RSA進(jìn)行加密解密方法,對(duì)此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: 国产视频一区在线 | 99久久精品一区二区成人 | 手机av免费在线 | 91久久国产综合久久 | 精品国产免费一区二区三区五区 | 青青草原综合久久大伊人精品 | 亚洲一区二区三区乱码aⅴ 四虎在线视频 | 国产精品揄拍一区二区 | 久在线观看 | 日日干日日 | 久久精品1| 九九热视频这里只有精品 | 一区中文字幕 | 亚洲视频一区在线观看 | 黑人巨大精品 | 亚洲福利在线观看 | 国产高清一区二区三区 | 一二三四在线视频观看社区 | 欧美在线视频一区二区 | av在线免费观看网址 | 国产精品久久久久影院色老大 | 怡红院免费的全部视频 | 欧美视频 | 国产高清视频一区二区 | 在线视频一区二区三区 | a级毛片基地 | 在线一区 | 免费一看一级毛片 | 黄色成人在线观看 | 欧美日韩在线观看视频 | 欧美在线a| 黄色一级网| 欧美日韩免费一区二区三区 | www.天堂av.com| 亚洲精品一区二区 | 五月激情六月婷婷 | 欧美精品久久一区 | 亚洲一区二区在线视频 | 日日夜夜精品免费视频 | 婷婷色国产偷v国产偷v小说 | 久久久久久国产精品免费免费狐狸 |