亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP4和PHP5版本下如何解析XML文檔

發布時間:2021-08-05 14:33:37 來源:億速云 閱讀:133 作者:小新 欄目:開發技術

這篇文章主要介紹PHP4和PHP5版本下如何解析XML文檔,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

XML文檔

<?xml version="1.0" encoding="gbk"?>
<LeapsoulXML>
<LeapsoulInfo>
<name>Leapsoul-PHP網站開發</name>
<website>https://www.jb51.net</website>
<description>分享PHP網站開發與建設的樂趣,教你如何建立網站</description>
<bloger>David</bloger>
<date>2009-05-13</date>
<qq>QQ:154130270</qq>
</LeapsoulInfo>
<LeapsoulInfo>
<name>Leapsoul-PHP網站開發</name>
<website>https://www.jb51.net</website>
<description>分享PHP網站開發與建設的樂趣,教你如何建立網站</description>
<bloger>David</bloger>
<date>2009-05-13</date>
<qq>QQ:154130270</qq>
</LeapsoulInfo>
</LeapsoulXML>

PHP5版本下SimpleXML的使用方法

$info=simplexml_load_file('leapsoulcn.xml');
print_r($info);
$name=$info->LeapsoulInfo[0]->name;
echo$name;
foreach($info->LeapsoulInfoas$LeapsoulInfo)
{
echo$LeapsoulInfo->name."<br />";
echo$LeapsoulInfo->website."<br />";
echo$LeapsoulInfo->description."<br />";
echo$LeapsoulInfo->bloger."<br />";
echo$LeapsoulInfo->date."<br />";
echo$LeapsoulInfo->qq."<br />";
}
foreach($info->xpath('//name')as$value){
echo$value.'<br />';
}
foreach($info->LeapsoulInfo[0]->children()as$value){
echo$value->getName();
echo$value.'<br />';
}
$info->LeapsoulInfo[0]->addChild('msn','MSN:davidfaithman@hotmail.com');
$info->asXML('leapsoulcn.xml');

代碼注釋

第1行:simplexml_load_file:讀取一個xml文檔作為操作對象,可以讀取本地或者遠程xml文檔;simplexml_load_string:讀取一個xml字符串作為操作的對象
第3行:如果不清楚如何獲取某個節點的信息,可用print_r函數打印輸出查看具體的結構,simplexml解析返回的對象具有數組結構。
第5~8行:以對象方式讀取某個XML文檔節點信息,讀取方式:句柄->節點元素名->子節點,如果相同的節點元素有多個,則以數組(array)方式讀取

注:由于simplexml解析返回的信息是UTF8格式的,如果網站使用的是GBK的,則需要轉碼,你可以使用iconv函數或者其他的utf8與gbk轉換函數進行操作,如:$name = iconv('utf-8′,'gbk',$name);

第9~17行:以遍歷的形式,讀取所有元素下的子節點信息
第19~21行:simplexml的xpath函數是用來查詢XML數據的,比如這里查詢的是所有name節點的值
第23~26行:children函數是用來找尋某個特定節點下所有子節點的值。getName函數用來獲得每個子節點的元素名稱
第28~29行:addChild函數用來在某個特定節點下增加一個子節點;asXML函數對已做過改動的XML文檔進行保存

點擊查看更多SimpleXML函數說明。

PHP4版本自帶的XML函數解析方法

function doStartElement($xmlParser,$name,$attr)
{
 //對開始元素的處理
}
function doEndElement($xmlParser,$name)
{
 //對結尾元素的處理
}
function doStringData($xmlParser,$data)
{
 //對元素間的字符數據的處理
}
$xmlObj = xml_parser_create("UTF-8");
xml_set_element_handler($xmlObj,"doStartElement","doEndElement");
xml_set_character_data_handler($xmlObj,"doStringData");
xml_parse($xmlObj,file_get_contents("leapsoulcn.xml"));
xml_parser_free($xmlObj);

代碼注釋

第1~15行:定義開始元素,結尾元素以及元素間字符數據的處理函數
第16行:建立一個新的XML解析器并返回可被其它XML函數使用的資源句柄,輸入默認編碼方式為 “ISO-8859-1”。同時,支持的編碼方式還有“UTF-8”和 “US-ASCII”,輸出數據編碼方式是和xml_parser_create函數處定義相一致。
第18行:建立起始和終止元素處理器
第20行:建立字符數據處理器,處理元素之間的相關數據
注:XML語法解析器不會加上或者去掉任何空格,空格的取舍將由開發者自己決定。
第22行:啟動解析器xml_parse函數第二個參數是字符型的,所以需要讀取相關的XML文檔信息,此處我用的是file_get_contents函數,本地遠程都可行,當然你也可以使用fopen函數
第24行:XML解析完成后,釋放解析器占用的內存

自帶的XML函數解析思路

第一步:自定義開始元素,結尾元素以及元素間字符數據的處理函數;
第二步:建立一個XML解析器;
第三步:建立起始和終止元素處理器;
第四步:建立字符數據處理器,處理元素之間的相關數據;
第五步:啟動解析器;
第六步:XML解析完成后,釋放解析器占用的內存。

以上是“PHP4和PHP5版本下如何解析XML文檔”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

顺昌县| 磐石市| 织金县| 南投县| 平谷区| 崇明县| 牙克石市| 西宁市| 新龙县| 新沂市| 卓尼县| 渑池县| 伊金霍洛旗| 呈贡县| 交口县| 安福县| 平和县| 康定县| 亚东县| 滁州市| 望都县| 晋州市| 阳春市| 巩义市| 都昌县| 普安县| 茂名市| 富锦市| 铁岭县| 汝南县| 西畴县| 饶阳县| 晋城| 镇平县| 山西省| 新丰县| 乐清市| 大化| 通江县| 新干县| 荔浦县|