中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

PHP讀取xml方法介紹

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

  XML(Extensible Markup Language)即可擴展標記語言,它與HTML一樣,都是SGML(Standard Generalized Markup Language,標準通用標記語言)。Xml是InterNET環(huán)境中跨平臺的,依賴于內容的技術,是當前處理結構化文檔信息的有力工具。擴展標記語言XML是一種簡單的數(shù)據(jù)存儲語言,使用一系列簡單的標記描述數(shù)據(jù),而這些標記可以用方便的方式建立,雖然XML占用的空間比二進制數(shù)據(jù)要占用更多的空間,但XML極其簡單易于掌握和使用。
XML的用途很多,可以用來存儲數(shù)據(jù),可以用來做數(shù)據(jù)交換,為很多種應用軟件提示數(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標簽的對象數(shù)組
foreach( $humans as $human )
{
$names = $human->getElementsByTagName( "name" ); //取得name的標簽的對象數(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>";
}
?>


  3)用php正則表達式來記取數(shù)據(jù)
復制代碼 代碼如下:
<?php
$xml = "";
$f = fopen('person.xml', 'r');
while( $data = fread( $f, 4096 ) ) {
$xml .= $data;
}
fclose( $f );
// 上面讀取數(shù)據(jù)
preg_match_all( "http://<humans/>(.*?)/<//humans/>/s", $xml, $humans ); //匹配最外層標簽里面的內容
foreach( $humans[1] as $k=>$human )
{
preg_match_all( "http://<name/>(.*?)/<//name/>/", $human, $name ); //匹配出名字
preg_match_all( "http://<sex/>(.*?)/<//sex/>/", $human, $sex ); //匹配出性別
preg_match_all( "http://<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++;
}
}
?>


  三,小結
  讀取xml的方法很多,簡單舉幾個。上面四種方法都是可以把標簽中的數(shù)據(jù)讀出來,張映.但是他們的測重點不同,前三種方法的讀取xml的function的設計重點,是為了讀取標簽中的值,相當于jquery中的text()方法,而xmlreader呢他就不太一樣,他的重點不在讀取標簽中的值,而讀取標簽的屬性,把要傳送的數(shù)據(jù),都放在屬性中(不過我上面寫的那個方法還是取標簽中的值,因為xml文件已經給定了,我就不想在搞xml文件出來了)。
  舉個例子解釋一下,
  <data name='張映' sex='男' old='28′></data>
  xmlreader的設計重點是為了讀data里面的name sex old的值,而讀取的內容就比較麻煩了。他相當于jquery中attr(”);這個東西。
  上面純屬個人看法,請大家指正。希望對大家有幫助。

php技術PHP讀取xml方法介紹,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 日韩三级电影一区二区 | 国产午夜精品一区二区三区嫩草 | 国产伦精品一区二区三区高清 | 亚洲网站在线观看 | 国产成人综合一区二区三区 | 久久久久久亚洲精品 | 国产精品有限公司 | aaaaaaa片毛片免费观看 | 国产一区 日韩 | 亚洲逼院 | 欧美精品在线播放 | 亚洲精品在线视频 | 一级黄色片在线看 | 91视视频在线观看入口直接观看 | 免费国产一区二区 | 在线播放一区二区三区 | 国产一区二区精品在线 | av大片 | 在线日韩福利 | 日韩国产中文字幕 | 亚洲一区在线播放 | 免费一区| 久久av在线播放 | 91精品久久久久久久久 | 日本成人中文字幕 | 正在播放国产精品 | 久久久久国产精品 | 黄色一级片aaa | 麻豆av在线 | 亚洲一区中文字幕 | 日韩电影中文字幕在线观看 | 久久一久久| 一区二区国产在线 | 毛片一区 | 精品一区二区三区四区五区 | 99这里只有精品视频 | 日本不卡免费新一二三区 | 欧美成视频 | 日本精品视频在线 | 无码一区二区三区视频 | 三级成人片 |