欧美国产另类久热|951超碰伊人久久|伊人影视久久久久|色婷婷亚洲小电影|色东京热69XX|婷婷玖玖深爱网|加勒比东京热网站|无码A级毛片在线观看|一级a毛一级a看|中文字幕人妻欧美

DOM基礎(chǔ)及php讀取xml內(nèi)容操作的方法
來源:易賢網(wǎng) 閱讀:997 次 日期:2015-02-05 14:07:58
溫馨提示:易賢網(wǎng)小編為您整理了“DOM基礎(chǔ)及php讀取xml內(nèi)容操作的方法”,方便廣大網(wǎng)友查閱!

DOM(Document Object Model):文檔對(duì)象模型。核心思想是:把 xml文件看作是一個(gè)對(duì)象模型,然后通過對(duì)象的方式來操作 xml 文件。

php對(duì)xml文檔進(jìn)行增刪改查(curd)操作,具體分析如下:

xml文檔:class.xml

代碼如下:

<?xml version="1.0" encoding="utf-8"?>

<class>

<student info="美女">

<name>小喬</name>

<sex>女</sex>

<age>20</age>

</student>

<student>

<name>周瑜</name>

<sex>男</sex>

<age>25</age>

</student>

</class>

class.xml 對(duì)應(yīng)的 DOM 樹結(jié)構(gòu)圖

名單

DOM基礎(chǔ)及php讀取xml內(nèi)容操作的方法 三聯(lián)

php文件(對(duì)xml文檔操作)

查詢操作案例:

代碼如下:

<?php

//1、創(chuàng)建一個(gè)DOMDocument對(duì)象。該對(duì)象就表示 xml文件

$xmldoc = new DOMDocument();

//2、加載xml文件(指定要解析哪個(gè)xml文件,此時(shí)dom樹節(jié)點(diǎn)就會(huì)加載到內(nèi)存中)

$xmldoc->load("class.xml");

//3、目標(biāo):獲取第一個(gè)學(xué)生的名字

//3.1 第一步,讀取所有的學(xué)生

$students = $xmldoc->getElementsByTagName("student");//方法getElementsByTagName:根據(jù)所給的節(jié)點(diǎn)名字(這里是student)查找 相應(yīng)的節(jié)點(diǎn),返回 DOMNodeList類型的對(duì)象,相當(dāng)于取出了所有的學(xué)生??梢杂胿ar_dump($students)查看,并根據(jù)返回值查找手冊(cè),看其下面的屬性與方法。

echo "共有 ".$students->length."個(gè)學(xué)生<br />";

//3.2 讀取第一個(gè)學(xué)生

$stu1 = $students->item(0);//讀取到第一個(gè)學(xué)生。返回值為DOMElement對(duì)象。直接 echo $stu1->nodeValue;則把name,sex,age都輸出。

//3.3 取出第一個(gè)學(xué)生的名字

$stu1_name = $stu1->getElementsByTagName("name");

//3.4 讀取到名字

echo $stu1_name->item(0)->nodeValue;

?>

注意點(diǎn):

(1)編碼問題;

(2)這里只是基礎(chǔ)演示,比較麻煩,后面用到循環(huán)和函數(shù)來操作;

(3)用var_dump(),查看變量的返回值是什么,再根據(jù)返回值到手冊(cè)中查找該返回值下的屬性與方法。

(4)整個(gè)順序下來,getElementByTagName()并不需要一層一層的讀,事實(shí)上可以直接讀取到節(jié)點(diǎn)name的,而不需要先讀取student(當(dāng)然,如果同一個(gè)student下,有多個(gè)name,就會(huì)出問題了,這里就需要學(xué)習(xí)新的知識(shí)點(diǎn)xpath)。

所以上面這代碼可以簡單改為:

代碼如下:

<?php

//1、創(chuàng)建一個(gè)DOMDocument對(duì)象。該對(duì)象就表示 xml文件

$xmldoc = new DOMDocument();

//2、加載xml文件(指定要解析哪個(gè)xml文件,此時(shí)dom樹節(jié)點(diǎn)就會(huì)加載到內(nèi)存中)

$xmldoc->load("class.xml");

//3、目標(biāo):獲取第一個(gè)學(xué)生的名字

$stu = $xmldoc->getElementsByTagName("name");//直接找到節(jié)點(diǎn)name

$stu1 = $stu->item(0);// item(1)時(shí),可以取到周瑜

echo $stu1->nodeValue;

?>

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:DOM基礎(chǔ)及php讀取xml內(nèi)容操作的方法
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn)

版權(quán)所有:易賢網(wǎng)