php xmlreader simplexml DOMDocument等讀取xml的例子

來源:互聯網
上載者:User

要處理 XML 檔案,有兩種傳統的處理思路: SAX 和 DOM 。 SAX 基於事件觸發機制,對 XML 檔案進行一次掃描,完成要進行的處理; DOM 則將整個 XML 檔案構造為一棵 DOM樹,通過對 DOM 樹的遍曆完成處理。這兩種方法各有優缺點, SAX 的處理思路相對抽象,DOM 的處理過程相對煩瑣,都不很適合新手的入門。PHP5 推出了一套新的 XML 處理函數,即 SimpleXML 。名如其實, SimpleXML 本身小巧精幹,只提供了少量的幾個方法函數,但用它處理起 XML 檔案功能卻非常強大,操作也非常的簡單。

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

XML(Extensible Markup Language)即可延伸標記語言 (XML),它與HTML一樣,都是SGML(Standard Generalized Markup Language,標準通用標記語言 (SGML))。Xml是Internet環境中跨平台的,依賴於內容的技術,是當前處理結構化文檔資訊的有力工具。擴充標記語言XML是一種簡單的資料存放區語言,使用一系列簡單的標記描述資料,而這些標記可以用方便的方式建立,雖然XML佔用的空間比位元據要佔用更多的空間,但XML極其簡單易於掌握和使用。
XML的用途很多,可以用來儲存資料,可以用來做資料交換,為很多種應用軟體提示資料等等。

二,php讀取xml的方法

xml源檔案
 

 代碼如下 複製代碼
<?xml version="1.0" encoding="UTF-8"?> 
  <humans> 
  <zhangying> 
  <name>張映</name> 
  <sex>男</sex> 
  <old>28</old> 
  </zhangying> 
  <tank> 
  <name>tank</name> 
  <sex>男</sex> 
  <old>28</old> 
  </tank> 
  </humans> 

1)DOMDocument讀取xml
 

 代碼如下 複製代碼
  <?php 
  $doc = new DOMDocument(); 
  $doc->load('person.xml');         //讀取xml檔案 
   
  $humans = $doc->getElementsByTagName( "humans" );         //取得humans標籤的對象數組 
 
  foreach( $humans as $human ) 
  { 
  $names = $human->getElementsByTagName( "name" );           //取得name的標籤的對象數組 
  $name = $names->item(0)->nodeValue;                                        //取得node中的值,如<name> </name> 
   
  $sexs = $human->getElementsByTagName( "sex" ); 
  $sex = $sexs->item(0)->nodeValue; 
  
  $olds = $human->getElementsByTagName( "old" ); 
  $old = $olds->item(0)->nodeValue; 
  
  echo "$name - $sex - $old\n"; 
  
  } 
  ?> 

2)simplexml讀取xml
 

 代碼如下 複製代碼
<?php 
$xml_array=simplexml_load_file('person.xml');                        //將XML中的資料,讀取到數組對象中 
 
foreach($xml_array as $tmp){ 
 echo $tmp->name."-".$tmp->sex."-".$tmp->old."<br>";    

 
?> 

3)用phpRegex來記取資料
 

 代碼如下 複製代碼
<?php 
  $xml = ""; 
  $f = fopen('person.xml', 'r'); 
  while( $data = fread( $f, 4096 ) ) { 
   $xml .= $data; 
  } 
  fclose( $f ); 
  // 上面讀取資料 
  preg_match_all( "/\<humans\>(.*?)\<\/humans\>/s", $xml, $humans );       //匹配最外層標籤裡面的內容 
   
  foreach( $humans[1] as $k=>$human ) 
  { 
   preg_match_all( "/\<name\>(.*?)\<\/name\>/", $human, $name );             //匹配出名字 
   preg_match_all( "/\<sex\>(.*?)\<\/sex\>/", $human, $sex );                        //匹配出性別 
   preg_match_all( "/\<old\>(.*?)\<\/old\>/", $human, $old );                        //匹配出年齡 
  } 
 
 foreach($name[1] as $key=>$val){ 
  echo $val." - ".$sex[$key][1]." - ".$old[$key][1]."<br>" ; 
 } 
?> 

4)xmlreader來讀取xml資料
 

 代碼如下 複製代碼

<?php 
$reader = new XMLReader(); 
$reader->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."<br>" ; 
  } 
  $i++; 
 } 

?> 


 

使用 DOMDocument 操控 XML

1. DOMDocument 解析 XML

 代碼如下 複製代碼

// 建立一個 DOMDocument()

$_doc = new DOMDocument();

// 載入 xml

$_doc ->load( 'test.xml' );

// 取 version 標籤

$_version = $_doc ->getElementsByTagName( 'version' );

echo $_version ->item( 2 )->nodeValue;

// 遍曆 version 標籤

foreach ( $_version as $v ) {

echo $v ->nodeValue;

}

2. DOMDocument 產生 XML

// 聲明 xml

$_doc = new DOMDocument( '1.0' , 'utf-8' );

// 排版格式

$_doc ->formatOutput = true ;

// 建立一個主標籤

$_root = $_doc ->createElement( 'root' );

// 建立一個一級標籤 version

$_version = $_doc ->createElement( 'version' );

// 給 version 標籤裡賦值

$_versionTextNode = $_doc ->createTextNode( '1.0' );

// 將值放入 version 標籤裡

$_version ->appendChild( $_versionTextNode );

// 將一級標籤 version 放入 root 裡

$_root ->appendChild( $_version );

// 將主標籤寫入 xml

$_doc ->appendChild( $_root );

// 產生 xml

$_doc ->save( 'aaa.xml' );


很多情況下 , 手工產生標記要求從上到下產生文檔 , 必須保證標籤都是完整的 , 開始和結束標籤。儘管藉助於一些 PHP 函數或類可以有所改善,不過 PHP 還提供了一組更有協助的內建對象和函數。文件物件模型( Document Object Model , DOM )提供了一個樹狀結構,能很容易建立和處理標籤。

三,小結

讀取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('');這個東西。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.