一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php中對(duì)xml讀取的相關(guān)函數(shù)的介紹一

對(duì)象 XML解析函數(shù) 描述 
元素 xml_set_element_handler() 元素的開始和結(jié)束 
字符數(shù)據(jù) xml_set_character_data_handler() 字符數(shù)據(jù)的開始 
外部實(shí)體 xml_set_external_entity_ref_handler() 外部實(shí)體出現(xiàn) 
未解析外部實(shí)體 xml_set_unparsed_entity_decl_handler() 未解析的外部實(shí)體出現(xiàn) 
處理指令 xml_set_processing_instruction_handler() 處理指令的出現(xiàn) 
記法聲明 xml_set_notation_decl_handler() 記法聲明的出現(xiàn) 
默認(rèn) xml_set_default_handler() 其它沒有指定處理函數(shù)的事件 

下面就給大家舉一個(gè)小小的例子用parser函數(shù)來讀取xml數(shù)據(jù): 

xml文件代碼如下: 

這個(gè)程序的結(jié)果如下:

引用: --------------------------------------------------------------------------------
名字:張三 職位:經(jīng)理
名字:李四 職位:助理
復(fù)制代碼 代碼如下:
<?xml version="1.0"?> 
<employees> 
<employee> 
<name>張三</name> 
<position age="45">經(jīng)理</position> 
</employee> 
<employees> 
<employee> 
<name>李四</name> 
<position age="45">助理</position> 
</employee> 
</employees> 


復(fù)制代碼 代碼如下:
<?php 
$parser = xml_parser_create(); //創(chuàng)建一個(gè)parser編輯器 
xml_set_element_handler($parser, "startElement", "endElement");//設(shè)立標(biāo)簽觸發(fā)時(shí)的相應(yīng)函數(shù) 這里分別為startElement和endElenment 
xml_set_character_data_handler($parser, "characterData");//設(shè)立數(shù)據(jù)讀取時(shí)的相應(yīng)函數(shù) 
$xml_file="1.xml";//指定所要讀取的xml文件,可以是url 
$filehandler = fopen($xml_file, "r");//打開文件 

while ($data = fread($filehandler, 4096))  

    xml_parse($parser, $data, feof($filehandler)); 
}//每次取出4096個(gè)字節(jié)進(jìn)行處理 

fclose($filehandler); 
xml_parser_free($parser);//關(guān)閉和釋放parser解析器 

$name=false; 
$position=false; 
function startElement($parser_instance, $element_name, $attrs)        //起始標(biāo)簽事件的函數(shù) 
 { 
   global $name,$position;   
   if($element_name=="NAME") 
   { 
   $name=true; 
   $position=false; 
   echo "名字:"; 
  } 
  if($element_name=="POSITION") 
   {$name=false; 
   $position=true; 
   echo "職位:"; 
  } 


function characterData($parser_instance, $xml_data)                  //讀取數(shù)據(jù)時(shí)的函數(shù)  

   global $name,$position; 
   if($position) 
    echo $xml_data."<br>"; 
    if($name) 
     echo $xml_data."<br>"; 


function endElement($parser_instance, $element_name)                 //結(jié)束標(biāo)簽事件的函數(shù) 

 global $name,$position;  
$name=false; 
$position=false;   


?> 


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)境中跨平臺(tái)的,依賴于內(nèi)容的技術(shù),是當(dāng)前處理結(jié)構(gòu)化文檔信息的有力工具。擴(kuò)展標(biāo)記語言XML是一種簡(jiǎn)單的數(shù)據(jù)存儲(chǔ)語言,使用一系列簡(jiǎn)單的標(biāo)記描述數(shù)據(jù),而這些標(biāo)記可以用方便的方式建立,雖然XML占用的空間比二進(jìn)制數(shù)據(jù)要占用更多的空間,但XML極其簡(jiǎn)單易于掌握和使用。
  XML的用途很多,可以用來存儲(chǔ)數(shù)據(jù),可以用來做數(shù)據(jù)交換,為很多種應(yīng)用軟件提示數(shù)據(jù)等等。
二,php讀取xml的方法
  xml源文件
復(fù)制代碼 代碼如下:
<?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
復(fù)制代碼 代碼如下:
<?php
$doc = new DOMDocument();
$doc->load('person.xml'); //讀取xml文件
$humans = $doc->getElementsByTagName( "humans" ); //取得humans標(biāo)簽的對(duì)象數(shù)組
foreach( $humans as $human )
{
$names = $human->getElementsByTagName( "name" ); //取得name的標(biāo)簽的對(duì)象數(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
復(fù)制代碼 代碼如下:
<?php
$xml_array=simplexml_load_file('person.xml'); //將XML中的數(shù)據(jù),讀取到數(shù)組對(duì)象中
foreach($xml_array as $tmp){
echo $tmp->name."-".$tmp->sex."-".$tmp->old."<br>";
}
?>

  3)用php正則表達(dá)式來記取數(shù)據(jù)
復(fù)制代碼 代碼如下:
<?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 ); //匹配最外層標(biāo)簽里面的內(nèi)容
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ù)
復(fù)制代碼 代碼如下:
<?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的方法很多,簡(jiǎn)單舉幾個(gè)。上面四種方法都是可以把標(biāo)簽中的數(shù)據(jù)讀出來,張映.但是他們的測(cè)重點(diǎn)不同,前三種方法的讀取xml的function的設(shè)計(jì)重點(diǎn),是為了讀取標(biāo)簽中的值,相當(dāng)于jquery中的text()方法,而xmlreader呢他就不太一樣,他的重點(diǎn)不在讀取標(biāo)簽中的值,而讀取標(biāo)簽的屬性,把要傳送的數(shù)據(jù),都放在屬性中(不過我上面寫的那個(gè)方法還是取標(biāo)簽中的值,因?yàn)閤ml文件已經(jīng)給定了,我就不想在搞xml文件出來了)。
  舉個(gè)例子解釋一下,
  <data name='張映' sex='男' old='28′></data>
  xmlreader的設(shè)計(jì)重點(diǎn)是為了讀data里面的name sex old的值,而讀取的內(nèi)容就比較麻煩了。他相當(dāng)于jquery中attr(”);這個(gè)東西。
  上面純屬個(gè)人看法,請(qǐng)大家指正。希望對(duì)大家有幫助。

php技術(shù)php中對(duì)xml讀取的相關(guān)函數(shù)的介紹一,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 国产在线激情 | 九一视频免费 | 婷婷色中文 | se97se成人亚洲网站在线观看 | 欧美日韩国产亚洲人成 | 久久精品一区 | 成人小视频在线免费观看 | 一色屋成人免费精品网站 | 色播在线视频 | 中文字幕一区二区三区视频在线 | 99re久久精品国产首页2020 | 欧美人与禽zoz0性伦交 | 久爱精品视频在线视频 | www91在线观看| 亚洲欧美一级久久精品 | 久热99这里只有精品视频6 | 香蕉eeww99国产在线观看 | 伊人网视频在线 | 日本精品高清一区二区2021 | 男女爱爱爽爽福利免费视频 | www.一区 | 久久r热这里有精品视频 | 久久91精品国产91久久跳舞 | 伊人久久精品 | 狠狠色伊人亚洲综合成人 | 天天综合日日噜噜噜 | 久久99久久99精品 | 2021国内精品久久久久久影院 | 国产色视频一区二区三区 | 久久精品国产99久久无毒不卡 | 国产精品玖玖 | 美女被性调教视频在线观看 | 亚洲国产精品日韩高清秒播 | 激情综合婷婷丁香六月花 | 免费国产精品视频 | 精品在线视频播放 | 国产精品特级毛片一区二区三区 | 精品国内一区二区三区免费视频 | 国产精品第1页在线播放 | 91精品国产自产在线观看 | 亚洲伦乱 |