在php中處理xml文檔的類或插件是非常的多了,今天我來為各位介紹xmlreader simplexmlDOMDocument 等讀取xml的例子,希望下文能幫助到大家.
要處理 XML 文件,有兩種傳統的處理思路:SAX 和 DOM,SAX 基于事件觸發機制,對 XML 文件進行一次掃描,完成要進行的處理,DOM 則將整個 XML 文件構造為一棵 DOM樹,通過對 DOM 樹的遍歷完成處理,這兩種方法各有優缺點,SAX 的處理思路相對抽象,DOM 的處理過程相對煩瑣,都不很適合新手的入門。PHP5 推出了一套新的 XML 處理函數,即 SimpleXML,名如其實,SimpleXML 本身小巧精干,只提供了少量的幾個方法函數,但用它處理起 XML 文件功能卻非常強大,操作也非常的簡單.
一,什么是xml,xml有什么用途
XML(Extensible Markup Language)即可擴展標記語言,它與HTML一樣,都是SGML(Standard Generalized Markup Language,標準通用標記語言)。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>
- //開源軟件:Vevb.com
- $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)用php正則表達式來記取數據,代碼如下:
- <?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('');這個東西.
新聞熱點
疑難解答