国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網(wǎng)站 > 建站經(jīng)驗(yàn) > 正文

PHP如何讀取xml文件?php讀取xml文檔例子

2024-04-25 20:36:58
字體:
供稿:網(wǎng)友

PHP如何讀取xml文件?有不少朋友不知道這個問題,其實(shí)php對于xml文檔是有專門的函數(shù)來操作了,下面我們就來舉幾個php讀取xml例子希望能給各位帶來幫助。

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

XML(Extensible Markup Language)即可擴(kuò)展標(biāo)記語言,它與HTML一樣,都是SGML(Standard Generalized Markup Language,標(biāo)準(zhǔn)通用標(biāo)記語言)。Xml是Internet環(huán)境中跨平臺的,依賴于內(nèi)容的技術(shù),是當(dāng)前處理結(jié)構(gòu)化文檔信息的有力工具。擴(kuò)展標(biāo)記語言XML是一種簡單的數(shù)據(jù)存儲語言,使用一系列簡單的標(biāo)記描述數(shù)據(jù),而這些標(biāo)記可以用方便的方式建立,雖然XML占用的空間比二進(jìn)制數(shù)據(jù)要占用更多的空間,但XML極其簡單易于掌握和使用。

XML的用途很多,可以用來存儲數(shù)據(jù),可以用來做數(shù)據(jù)交換,為很多種應(yīng)用軟件提示數(shù)據(jù)等等。

二,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標(biāo)簽的對象數(shù)組

foreach( $humans as $human )

{

$names = $human->getElementsByTagName( "name" ); //取得name的標(biāo)簽的對象數(shù)組

$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中的數(shù)據(jù),讀取到數(shù)組對象中

foreach($xml_array as $tmp){

echo $tmp->name."-".$tmp->sex."-".$tmp->old."<br>";

}

?>

如果你使用 curl 獲取的 xml data

$xml = simplexml_load_string($data);

$data['tk'] = json_decode(json_encode($xml),TRUE);

如果是直接獲取 URL 數(shù)據(jù)的話

$xml = simplexml_load_file($data);

$data['tk'] = json_decode(json_encode($xml),TRUE);

先把 simplexml 對象轉(zhuǎn)換成 json,再將 json 轉(zhuǎn)換成數(shù)組。

3)用php正則表達(dá)式來記取數(shù)據(jù)

<?php

$xml = "";

$f = fopen('person.xml', 'r');

while( $data = fread( $f, 4096 ) ) {

$xml .= $data;

}

fclose( $f );

// 上面讀取數(shù)據(jù)

preg_match_all( "/\<humans\>(.*?)\<\/humans\>/s", $xml, $humans ); //匹配最外層標(biāo)簽里面的內(nèi)容

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數(shù)據(jù)

<?php

$reader = new XMLReader();

$reader->open('person.xml'); //讀取xml數(shù)據(jù)

$i=1;

while ($reader->read()) { //是否讀取

if ($reader->nodeType == XMLReader::TEXT) { //判斷node類型

if($i%3){

echo $reader->value; //取得node的值

}else{

echo $reader->value."<br>" ;

}

$i++;

}

}

?>

三,小結(jié)

讀取xml的方法很多,簡單舉幾個。上面四種方法都是可以把標(biāo)簽中的數(shù)據(jù)讀出來,張映.但是他們的測重點(diǎn)不同,前三種方法的讀取xml的function的設(shè)計(jì)重點(diǎn),是為了讀取標(biāo)簽中的值,相當(dāng)于jquery中的text()方法,而xmlreader呢他就不太一樣,他的重點(diǎn)不在讀取標(biāo)簽中的值,而讀取標(biāo)簽的屬性,把要傳送的數(shù)據(jù),都放在屬性中(不過我上面寫的那個方法還是取標(biāo)簽中的值,因?yàn)閤ml文件已經(jīng)給定了,我就不想在搞xml文件出來了)。

舉個例子解釋一下,

<data name=’張映’ sex=’男’ old=’28′></data>

xmlreader的設(shè)計(jì)重點(diǎn)是為了讀data里面的name sex old的值,而讀取的內(nèi)容就比較麻煩了。他相當(dāng)于jquery中attr(”);這個東西。

 

 

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 岫岩| 岳池县| 遵义县| 济阳县| 兴山县| 宣威市| 奉新县| 镇康县| 西城区| 汕头市| 密山市| 澄迈县| 温宿县| 博爱县| 金溪县| 宁陵县| 德州市| 芷江| 临沂市| 东丰县| 维西| 镇平县| 巴南区| 达州市| 葫芦岛市| 湖州市| 天水市| 太白县| 航空| 元江| 五台县| 嘉义市| 五原县| 宜春市| 乌拉特中旗| 边坝县| 伊通| 哈密市| 论坛| 清水河县| 胶南市|