php中對xml讀取的相關函數的介紹一_PHP教程
來源:互聯網
上載者:User
對象 XML解析函數 描述
元素 xml_set_element_handler() 元素的開始和結束
字元資料 xml_set_character_data_handler() 字元資料的開始
外部實體 xml_set_external_entity_ref_handler() 外部實體出現
未解析外部實體 xml_set_unparsed_entity_decl_handler() 未解析的外部實體出現
處理指示 xml_set_processing_instruction_handler() 處理指示的出現
記法聲明 xml_set_notation_decl_handler() 記法聲明的出現
預設 xml_set_default_handler() 其它沒有指定處理函數的事件
下面就給大家舉一個小小的例子用parser函數來讀取xml資料:
xml檔案代碼如下:
這個程式的結果如下:
引用: --------------------------------------------------------------------------------
名字:張三 職位:經理
名字:李四 職位:助理
複製代碼 代碼如下:
張三
經理
李四
助理
複製代碼 代碼如下:
$parser = xml_parser_create(); //建立一個parser編輯器
xml_set_element_handler($parser, "startElement", "endElement");//設立標籤觸發時的相應函數 這裡分別為startElement和endElenment
xml_set_character_data_handler($parser, "characterData");//設立資料讀取時的相應函數
$xml_file="1.xml";//指定所要讀取的xml檔案,可以是url
$filehandler = fopen($xml_file, "r");//開啟檔案
while ($data = fread($filehandler, 4096))
{
xml_parse($parser, $data, feof($filehandler));
}//每次取出4096個位元組進行處理
fclose($filehandler);
xml_parser_free($parser);//關閉和釋放parser解析器
$name=false;
$position=false;
function startElement($parser_instance, $element_name, $attrs) //起始標籤事件的函數
{
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) //讀取資料時的函數
{
global $name,$position;
if($position)
echo $xml_data."
";
if($name)
echo $xml_data."
";
}
function endElement($parser_instance, $element_name) //結束標籤事件的函數
{
global $name,$position;
$name=false;
$position=false;
}
?>
PHP讀取xml方法介紹
一,什麼是xml,xml有什麼用途
XML(Extensible Markup Language)即可延伸標記語言 (XML),它與HTML一樣,都是SGML(Standard Generalized Markup Language,標準通用標記語言 (SGML))。Xml是Internet環境中跨平台的,依賴於內容的技術,是當前處理結構化文檔資訊的有力工具。擴充標記語言XML是一種簡單的資料存放區語言,使用一系列簡單的標記描述資料,而這些標記可以用方便的方式建立,雖然XML佔用的空間比位元據要佔用更多的空間,但XML極其簡單易於掌握和使用。
XML的用途很多,可以用來儲存資料,可以用來做資料交換,為很多種應用軟體提示資料等等。
二,php讀取xml的方法
xml源檔案
複製代碼 代碼如下:
張映
男
28
tank
男
28
1)DOMDocument讀取xml
複製代碼 代碼如下:
$doc = new DOMDocument();
$doc->load('person.xml'); //讀取xml檔案
$humans = $doc->getElementsByTagName( "humans" ); //取得humans標籤的對象數組
foreach( $humans as $human )
{
$names = $human->getElementsByTagName( "name" ); //取得name的標籤的對象數組
$name = $names->item(0)->nodeValue; //取得node中的值,如
$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
複製代碼 代碼如下:
$xml_array=simplexml_load_file('person.xml'); //將XML中的資料,讀取到數組對象中
foreach($xml_array as $tmp){
echo $tmp->name."-".$tmp->sex."-".$tmp->old."
";
}
?>
3)用phpRegex來記取資料
複製代碼 代碼如下:
$xml = "";
$f = fopen('person.xml', 'r');
while( $data = fread( $f, 4096 ) ) {
$xml .= $data;
}
fclose( $f );
// 上面讀取資料
preg_match_all( "/\(.*?)\<\/humans\>/s", $xml, $humans ); //匹配最外層標籤裡面的內容
foreach( $humans[1] as $k=>$human )
{
preg_match_all( "/\(.*?)\<\/name\>/", $human, $name ); //匹配出名字
preg_match_all( "/\(.*?)\<\/sex\>/", $human, $sex ); //匹配出性別
preg_match_all( "/\(.*?)\<\/old\>/", $human, $old ); //匹配出年齡
}
foreach($name[1] as $key=>$val){
echo $val." - ".$sex[$key][1]." - ".$old[$key][1]."
" ;
}
?>
4)xmlreader來讀取xml資料
複製代碼 代碼如下:
$reader = new XMLReader();
$reader->open('person.xml'); //讀取xml資料
$i=1;
while ($reader->read()) { //是否讀取
if ($reader->nodeType == XMLReader::TEXT) { //判斷node類型
if($i%3){
echo $reader->value; //取得node的值
}else{
echo $reader->value."
" ;
}
$i++;
}
}
?>
三,小結
讀取xml的方法很多,簡單舉幾個。上面四種方法都是可以把標籤中的資料讀出來,張映.但是他們的測重點不同,前三種方法的讀取xml的function的設計重點,是為了讀取標籤中的值,相當於jquery中的text()方法,而xmlreader呢他就不太一樣,他的重點不在讀取標籤中的值,而讀取標籤的屬性,把要傳送的資料,都放在屬性中(不過我上面寫的那個方法還是取標籤中的值,因為xml檔案已經給定了,我就不想在搞xml檔案出來了)。
舉個例子解釋一下,